zoukankan      html  css  js  c++  java
  • POJ 2584 T-Shirt Gumbo(二分图最大匹配)

    题意:

    有五种衣服尺码:S,M,L,X,T

    N个人,每个人都有一个可以穿的衣服尺码的范围,例:SX,意思是可以穿S,M,L,X的衣服。

    给出五种尺码的衣服各有多少件。

    如果可以满足所有人的要求,输出 T-shirts rock! 否则输出 I'd rather not wear a shirt anyway...

    样例:

    输入:

    START 1
    ST
    0 0 1 0 0
    END
    START 2
    SS TT
    0 0 1 0 0
    END
    START 4
    SM ML LX XT
    0 1 1 1 0
    END
    ENDOFINPUT

    输出:

    T-shirts rock!
    I'd rather not wear a shirt anyway...
    I'd rather not wear a shirt anyway...

    思路:

    人数不多,衣服总件数也不多,直接建图,左集合是人,右集合是每一件衣服。二分图最大匹配。看代码。

    代码:

    char st[105];
    char Range[25][5];
    int n;
    int num[10];
    int cx[25],cy[205];
    bool bmask[205];
    vector<int> graph[25];
    
    
    int findPath(int u){
        int L=graph[u].size();
        rep(i,0,L-1){
            int v=graph[u][i];
            if(!bmask[v]){
                bmask[v]=true;
                if(cy[v]==-1||findPath(cy[v])){
                    cy[v]=u;
                    cx[u]=v;
                    return 1;
                }
            }
        }
        return 0;
    }
    int MaxMatch(){
        int ans=0;
        rep(i,1,n) cx[i]=-1;
        rep(i,1,num[5]) cy[i]=-1;
        rep(i,1,n) if(cx[i]==-1){
            mem(bmask,false);
            ans+=findPath(i);
        }
        return ans;
    }
    
    int main(){
        map<char,int> mp;
        mp['S']=1; mp['M']=2; mp['L']=3; mp['X']=4; mp['T']=5;
        while(scanf("%s",st)!=EOF){
            if(strcmp(st,"ENDOFINPUT")==0) break;
            scanf("%d",&n);
            rep(i,1,n) scanf("%s",Range[i]);
    
            num[0]=0;
            rep(i,1,5){
                int x;
                scanf("%d",&x);
                num[i]=num[i-1]+x;
            }
            scanf("%s",st);
    
            rep(i,1,n) graph[i].clear();
            rep(i,1,n){
                int u=mp[Range[i][0]], v=mp[Range[i][1]];
                rep(j,num[u-1]+1,num[v]) graph[i].push_back(j);
            }
            int dd=MaxMatch();
            if(dd>=n)
                puts("T-shirts rock!");
            else
                puts("I'd rather not wear a shirt anyway...");
        }
    }
  • 相关阅读:
    Git for Android Studio 学习笔记
    ACM-线段树区间更新+离散化
    hdu 1394 逆序数(线段树)
    Android瀑布流照片
    Android照片墙-多图加载
    Android-加载图片避免OOM
    Android-自定义View实现ImageView播放gif
    maven---工程建立及目录添加--
    oracle--视图(2)---
    Hibernate---Hql查询2---
  • 原文地址:https://www.cnblogs.com/fish7/p/4094911.html
Copyright © 2011-2022 走看看