poj2492 poj1182种类并查集

   这两道题感觉有点难,自己琢磨了好一阵子也没什么结果最后还得大神的思维啊!!  

poj 1182点击打开链接

分析:这个题大意说的非常清楚了,就是求出假话的个数,题目中给的假话要求有三个 

 当前的话与前面的某些真的话冲突,是假话; 

当前的话中X或Y比N大,是假话;

当前的话表示X吃X,是假话。  

②和③很好判断了,最难的就是假话条件①啦!!    题中说有三种动物A,B,C;   A-->B-->C-->A(A吃B, B吃C,C又吃A), 形成一个环; 然而我们又没办法把所给的动物(数字代替)确切的分给哪一类。 那么就不分了,既然这三种动物构成一个环么,那么我们就将所有相关联的元素合并成一个集合。 集合中有一个代表元素(下面也可能叫根元素)。 通过元素与根元素的关系  来区别他们。 relation[i] = 0 表示与根元素同类relation[i] = 1 表示吃根元素的那类, relation[i] = 2 表示被根元素吃的一类。 通过元素与根元素的关系清晰的将他们分为三类,又不用确切表明哪一类。

      


Union2  relation[fx] = (3 + (relation[b] - relation[a]) + 1) % 3;

x与根元素fx的关系y与根元素fy的关系fx与fy的关系relation[b] - relation[a]
0                         010
100-1
202-2
0121
1110
210-1
0202
1221
2210

Union1      relation[fx] = (3 + (relation[b] - relation[a])) % 3;

x与根元素fx的关系y与根元素fy的关系fx与fy的关系relation[b] - relation[a]
0000
0111
0222
102-1
1100
1211
201-2
212-1
2200


find   relation[i] = (relation[i] + relation[j]) % 3;

i元素与父亲元素j的关系j元素与根元素的关系i元素与根元素的关系
000
011
022
101
112
120
202
210
221

poj2492 和这个题类似 , 他只是将A,B,C三类动物 变成 男,女两种类。relation可能是同类或异类。如果出现一对是同类那么说明 有异常。 relation关系式:   find寻找时relation[i] = (relation[i] + relation[j]) % 2;    合并时relation[fx] = (relation[a] + relation[b] + 1) % 2。







  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值