bzoj 1370 团伙 并查集

61 篇文章 0 订阅
15 篇文章 0 订阅

题意:n个人,朋友的朋友是我的朋友,敌人的敌人是我的朋友,互为朋友的组成一个团伙,问团伙的数量

并查集入门题

把一个人拆成两个,x表示朋友集合,n+x表示敌人集合

朋友的朋友是我的朋友:直接合并x和y

敌人的敌人是我的朋友:合并x和n+y ,合并 y 和n+1

var
        n,m,x,y,ans     :longint;
        vis             :array[0..2010] of boolean;
        f               :array[0..2010] of longint;
        i               :longint;
        ch              :char;
function get_father(x:longint):longint;
begin
   if x=f[x] then exit(x);
   f[x]:=get_father(f[x]);
   exit(f[x]);
end;

procedure connect(x,y:longint);
begin
   x:=get_father(x);
   y:=get_father(y);
   if (x<>y) then f[x]:=y;
end;

begin
   read(n);
   for i:=1 to 2*n do f[i]:=i;
   readln(m);
   for i:=1 to m do
   begin
      read(ch); readln(x,y);
      if ch='F' then connect(x,y) else
      begin
         connect(x,n+y);
         connect(y,n+x);
      end;
   end;
   ans:=0;
   for i:=1 to n do
   begin
       x:=get_father(i);
       if not vis[x] then
       begin
          inc(ans);
          vis[x]:=true;
       end;
   end;
   writeln(ans);
end.
——by Eirlys

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值