Codeforces Round #170 (Div. 2) C. Learning Languages 并查集

链接:

http://codeforces.com/contest/278/problem/C

题意:

有n个员工,m种语言,每名员工可能会几种语言,也可能0门,

问最少需要在学多少门语言,使得任意两个人可以直接或者间接沟通

题解:

不区分员工和语言,直接用并查集就行了,最后就是集合数-1

但是要注意如果所有的人都会0门语言的话,结果就是n

代码:

31 int n, m;
32 int par[220];
33 int vis[220];
34 
35 int find(int x) {
36     return par[x] = par[x] == x ? x : find(par[x]);
37 }
38 
39 void unite(int x, int y) {
40     int a = find(x), b = find(y);
41     if (a != b) par[a] = b;
42 }
43 
44 int main() {
45     ios::sync_with_stdio(false), cin.tie(0);
46     cin >> n >> m;
47     rep(i, 0, 220) par[i] = i;
48     int fg = 0;
49     rep(i, 1, n + 1) {
50         int k;
51         cin >> k;
52         if(k) fg = 1;
53         while (k--) {
54             int a;
55             cin >> a;
56             a += 100;
57             unite(i, a);
58         }
59     }
60     if (!fg) return (cout << n << endl), 0;
61     int ans = 0;
62     rep(i, 1, n + 1) if (!vis[find(i)]) {
63         ans++;
64         vis[find(i)] = 1;
65     }
66     cout << ans - 1 << endl;
67     return 0;
68 }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值