superman

聚精会神搞建设 一心一意谋发展
posts - 190, comments - 17, trackbacks - 0, articles - 0
   :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

ZOJ 1137 - Girls and Boys

Posted on 2008-04-23 15:54 superman 阅读(340) 评论(0)  编辑 收藏 引用 所属分类: ZOJ
 1 /* Accepted 1137 C++ 00:07.49 1820K */
 2 #include <iostream>
 3 
 4 using namespace std;
 5 
 6 int n, match[1000];
 7 bool map[1000][1000], visited[1000];
 8 
 9 bool dfs(int p)
10 {
11      for(int i = 0; i < n; i++)
12           if(map[p][i] && visited[i] == false)
13           {
14                visited[i] = true;
15                if(match[i] == -1 || dfs(match[i]))
16                {
17                     match[i] = p;
18                     return true;
19                }
20           }
21      return false;
22 }
23 
24 int main()
25 {
26      while(cin >> n)
27      {
28           memset(map, falsesizeof(map));
29           memset(match, 255sizeof(match));
30           
31           int s, t, m;
32           for(int i = 0; i < n; i++)
33           {
34                scanf("%d: (%d)"&s, &m);
35                while(m--)
36                {
37                     cin >> t;
38                     map[s][t] = true;
39                }
40           }
41           
42           int cnt = 0;
43           for(int i = 0; i < n; i++)
44           {
45                memset(visited, falsesizeof(visited));
46                cnt += dfs(i);
47           }
48           cout << n - cnt / 2 << endl;     
49      }
50      
51      return 0;
52 }
53 

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理