08220420

二分匹配——hdu1083

邻接表

#include<iostream>
using namespace std;
int g[333][333], vis[333], lin[333], n;

int find(int node) {
    
for (int i = 1; i <= g[node][0]; i++)
        
if (!vis[g[node][i]]) {
            vis[g[node][i]] 
= 1;
            
if (!lin[g[node][i]] || find(lin[g[node][i]])) {
                lin[g[node][i]] 
= node;
                
return 1;
            }

        }

    
return 0;
}


int main() {
    
int cas, i, j, x, p;
    cin 
>> cas;
    
while (cas--{
        memset(g, 
0sizeof g);
        cin 
>> p >> n;
        
for (i = 1; i <= p; i++{
            
int m;
            cin 
>> m;
            
for (j = 1; j <= m; j++)
                cin 
>> g[i][++g[i][0]];
        }

        memset(lin, 
0sizeof lin);
        
for (i = 1; i <= p; i++{
            memset(vis, 
0sizeof vis);
            
if (!find(i))break;
        }

        
if (i <= p)cout << "NO" << endl;
        
else cout << "YES" << endl;
    }

}




邻接矩阵

 1 #include<iostream>
 2 using namespace std;
 3 int g[333][333], vis[333], lin[333], n;
 4 
 5 int find(int node){
 6     for (int i = 1; i <= n; i++)
 7         if (!vis[i] && g[node][i]) {
 8             vis[i] = 1;
 9             if (!lin[i] || find(lin[i])) {
10                 lin[i] = node;
11                 return 1;
12             }
13         }
14     return 0;
15 }
16 
17 int main(){
18     int cas, i, j, x, p;
19     cin >> cas;
20     while (cas--) {
21         memset(g, 0sizeof g);
22         cin >> p >> n;
23         for (i = 1; i <= p; i++) {
24             int m;
25             cin >> m;
26             for (j = 1, x; j <= m; j++)
27                 cin >> x, g[i][x] = 1;
28         }
29         memset(lin, 0sizeof lin);
30         for (i = 1; i <= p; i++) {
31             memset(vis, 0sizeof vis);
32             if (!find(i))break;
33         }
34         if (i <= p)cout << "NO" << endl;
35         else cout << "YES" << endl;
36     }
37 }
38 

posted on 2010-03-09 20:58 hxyoung 阅读(136) 评论(0)  编辑 收藏 引用


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


导航

<2024年11月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

统计

常用链接

留言簿

随笔档案

文章档案

搜索

最新评论

阅读排行榜

评论排行榜