摘要: 题意:这道题很有意思。他是给你一个无向图然后让你把尽量多的边转化成单向边,然后是整张图还是强联通的。思路:看到这道题的第一反应就是求割边,应为割边所连接的都是双连通分支对于双连通分支我们只需要化成单向边就能解决问题。然后对于割边我们才需要化成双向边。之后我就考虑了一下如何输出答案。这很容易就类似于欧拉通路我开了两个标记数组,一个标记点,另一个标记边。输出一条标记一条即可。注意不要经过桥。然后最后再把所有的桥输出就可以了。代码如下: 1 /************************************************** 2 * Author : xiaohao Z ... 阅读全文
posted @ 2014-01-29 16:07 张小豪 阅读(311) 评论(0) 推荐(0) 编辑
摘要: 题意:有一些骨牌,告诉你一些关系a->b表示a倒了b也会倒。然后问你最少要推到几个才能使所有的骨牌都倒下。思路:这道题其实就是用的强连通分支的kosaraju算法。其实在了解了这个算法之后我们不妨来想想是怎么样的一个逻辑关系。第一遍dfs我们先得到了在vs数组中的拓扑关系。到了第二遍,我们就从拓扑序列高的先开始dfs(可以直观的了解到只要拓扑序列高的倒下了,那么拓扑序列低的必定倒下了)所以我们得到的dfs次数即为答案了。代码如下: 1 /************************************************** 2 * Author : xiaohao Z .. 阅读全文
posted @ 2014-01-29 14:20 张小豪 阅读(278) 评论(0) 推荐(0) 编辑