免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4314 | 回复: 17
打印 上一主题 下一主题

[算法] 最小生成树正确性证明 [复制链接]

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-01-27 18:06 |只看该作者 |倒序浏览
本帖最后由 _nosay 于 2016-01-27 18:24 编辑

参考的《算法导论》,自己再总结一遍,巩固一下理解:

原始图信息:


一种最小生成树(红色部分):

同一个图可能有多个最小生成树,比如cd=ef,则用ef替换cd就出现另一个最小生成树。

上述最小生成树中的一部分:

我们已经确定该图中的红色路径,为某一个最小生成树的一部分,现将已经经过的点和未经过的点,用一条黑线隔开,则ah、bd、cd、df、ef跨越了这条线,并假设cd是这5条路径中最短的一条。

到此为止,铺垫完毕,现要证明“下一步必须走跨越黑线的最短路径(cd)”。
证明:
1. 先证明“以下情况下走cd也可以生成最小生成树T’ ”:
   假设,图2画的最小生成树T中不包含cd。
   那么,想从c走到d,一定是“绕着”走的,比如cf→ef→ed,但无论如何都得穿过黑线,所以必须包含剩余4条路径中的一条,假设为ef。
   另外,最小生成树中,任意2点之间只可能有1条路径,否则就成环了,对于环中相邻的2点来说,直接相连的路径就可以省去
   ① T连接hgfci和abde只需要ef,现在T’改从cd走,仍然可以将内外两部分全部连通,所以T’仍然是生成树;
          
   ② 由于T为最小生成树,所以它的总权重小于等于任意其它生成树:w(T)≦w(T’)
        由于T’用cd替换了ef,cd为跨越黑线的最短路径,即cd≦ef,所以w(T’)≦w(T)
        所以w(T’)=w(T),即T’ “也”最小。
   证毕。
2. 证明“必须”:
   如果不走跨越黑线的最短路径,就不能保证“w(T’)≦w(T)”,即证明过程1就无法证明T’ “也”最小。
证毕。

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-12-23 06:20:00每日论坛发贴之星
日期:2015-12-23 06:20:00
2 [报告]
发表于 2016-01-29 23:43 |只看该作者
加油

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
3 [报告]
发表于 2016-01-29 23:50 |只看该作者
alwaysR9 发表于 2016-01-29 23:43
加油


哇~ 谢谢鼓励

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
4 [报告]
发表于 2016-01-30 01:10 |只看该作者
这个版是C/C++,下次如果你光贴算法不贴C/C++代码的话我就删帖了。

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
5 [报告]
发表于 2016-01-30 09:26 |只看该作者
windoze 发表于 2016-01-30 01:10
这个版是C/C++,下次如果你光贴算法不贴C/C++代码的话我就删帖了。


版主不喜欢无码是吧,那下次这种贴,我写在灌水区吧,那里对内容限制会少点吧。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
6 [报告]
发表于 2016-01-30 11:40 |只看该作者
回复 5# _nosay

nonono,我的意思是说你要把最小生成树的程序代码一块贴出来。

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
7 [报告]
发表于 2016-01-30 15:56 |只看该作者
windoze 发表于 2016-01-30 11:40
回复 5# _nosay

nonono,我的意思是说你要把最小生成树的程序代码一块贴出来。


prim,kruskal,网上已经有很多写的很漂亮的代码了,但是关于证明的文章比较少,而且不是很严格,所以我就只总结了证明过程

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
8 [报告]
发表于 2016-01-30 18:44 |只看该作者
回复 7# _nosay

漂亮不漂亮没关系,关键是要自己写一遍。
编程就是这样,不动手看再多paper也没用。

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
9 [报告]
发表于 2016-01-30 19:05 |只看该作者
windoze 发表于 2016-01-30 18:44
回复 7# _nosay

漂亮不漂亮没关系,关键是要自己写一遍。


是的,版主教育的是

论坛徽章:
223
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-05-10 19:22:58操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:10操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
10 [报告]
发表于 2016-01-30 20:36 来自手机 |只看该作者
本帖最后由 action08 于 2016-01-30 20:36 编辑

版主神逻辑哦

老祖宗早就总结了,唯有读书才能使人进步
在不少公司生态,代码控是活得最苦逼的,不要写也罢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP