摘要: 题目链接:http://poj.org/problem?id=1679 求是否存在多个最小生成树,其实就是求次小生成树的权值是否等于最小生成树。 最小生成树的两个性质: 1.切割性质:假定所有边权值不相等,设S为即非空集合也非全集V的子集,边e是满足一个端点在S内,另一个端点不在S内的所有边中权值最小的一个,则图G的所有生成树均包含e。 2.回路性质:假定所有边权值不相等,设C是图G中的任意回路,边e是C上权值最大的边,则图G的所有生成树均不包含e。 求次小生成树一遍朴素的做法就是枚举最小生成树中的边删去,然后再在图上求最小生成树,复杂度O(n*m*lgm);对于稀疏图来... 阅读全文
posted @ 2013-01-31 12:45 zhsl 阅读(240) 评论(0) 推荐(0) 编辑
摘要: 题目链接:http://poj.org/problem?id=3635 容易想到用二维数组记录状态求最短路,然后用优先队列优化,类似于Dijkstra和BFS。我开始设计的过程是直接直接从当前点向相邻点转移并找出所有可能状态,结果TLE。貌似是无关状态太多了,没想到卡得这么紧。别人的做法是只考虑两个状态:1、加一单位油 2、向相邻点移动;这样就砍掉了一些对最优解不必要的状态。 1 //STATUS:C++_AC_297MS_2404KB 2 #include<stdio.h> 3 #include<stdlib.h> 4 #include<string.h> 阅读全文
posted @ 2013-01-31 00:03 zhsl 阅读(299) 评论(0) 推荐(0) 编辑