题目地址
单看题目的话和hdu1272是一样的。但是hdu1272的博文中我也说了,数据比较水,所以我用非并查集的方法就AC了。但是这题的数据没那么水,要用到并查集来解。这题的盲点和重点有这么几个:
- 输入不是以-1 -1结束,而是以两个负数结束
- 需要用并查集来判断是不是只有一个“根”
- 需要判断所有节点的入度是否大于1
- 本题输入的格式,也要注意一下。
可以先忽略图中的方向的。因为如果有环的话,就变成图了,若严格的按照用parent数组来保存上一级父节点的方法,会有冲突。
比如这个图中,8的父节点有两个那么parent[8]应该如何存储呢??所以我们可以把它看成无向图,无所谓父子,只需把关系集合merge合并就好了。这种有多个父节点的情况,就使用一个记录入度的数组来标记就好了。
#include<i