标签:none 题目 iss ted tput correct src star ems
题目链接:https://vjudge.net/problem/HDU-1083
Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 8869 Accepted Submission(s): 4319
题解:
有n个学生,m门选修课。给出选课情况,问能否为每门科目安排一位课代表?
求出最大匹配数,即一门选修课与一个学生匹配。如果最大匹配数等于选修课的数目,则可以为每门科目安排一位课代表;否则不能。
代码如下:
1 #include <iostream> 2 #include <cstdio> 3 #include <cstring> 4 #include <cstdlib> 5 #include <string> 6 #include <vector> 7 #include <map> 8 #include <set> 9 #include <queue> 10 #include <sstream> 11 #include <algorithm> 12 using namespace std; 13 const int INF = 2e9; 14 const int MOD = 1e9+7; 15 const int MAXN = 300+10; 16 17 int uN, vN; 18 char a[MAXN][MAXN]; 19 int M[MAXN][MAXN], link[MAXN]; 20 bool vis[MAXN]; 21 22 bool dfs(int u) 23 { 24 for(int i = 1; i<=vN; i++) 25 if(M[u][i] && !vis[i]) 26 { 27 vis[i] = true; 28 if(link[i]==-1 || dfs(link[i])) 29 { 30 link[i] = u; 31 return true; 32 } 33 } 34 return false; 35 } 36 37 int hungary() 38 { 39 int ret = 0; 40 memset(link, -1, sizeof(link)); 41 for(int i = 1; i<=uN; i++) 42 { 43 memset(vis, 0, sizeof(vis)); 44 if(dfs(i)) ret++; 45 } 46 return ret; 47 } 48 49 int main() 50 { 51 int T; 52 scanf("%d", &T); 53 while(T--) 54 { 55 scanf("%d%d", &uN, &vN); 56 memset(M, false, sizeof(M)); 57 for(int i = 1; i<=uN; i++) 58 { 59 int m, v; 60 scanf("%d", &m); 61 while(m--) 62 { 63 scanf("%d", &v); 64 M[i][v] = true; 65 } 66 } 67 68 int cnt = hungary(); 69 if(cnt==uN) puts("YES"); 70 else puts("NO"); 71 } 72 }
标签:none 题目 iss ted tput correct src star ems
原文地址:http://www.cnblogs.com/DOLFAMINGO/p/7818208.html