poj Redundant Paths

来源:互联网 发布:aes算法 编辑:程序博客网 时间:2024/05/02 04:51

1.理解题意后可以发现要求的图是任意两点间存在至少两条不相同的路径,这里自己犯了个错误,误以为只要简单的两两匹配度数为1的点既能得到答案,这种想法错误的原因在于:可能存在一点度数>1但与它对应的存在桥边.

   虽然想简单了,但是可以立即发现,问题的关键在于桥边(其实题意要求的就是双连通分量)

2.用tarjan求桥边,桥边性质:存在(u,v)两点u->v,并且DFN(u)<LOW[v];

3.其它的就只剩缩点和求缩点后度数为1的结点数目了,,这里有个小技巧是:由于删除桥边后图中的点被分割成一块一块的连通分量,所以只要一个dfs()既能给所有点打上标签了

原创粉丝点击