- 在线时间
- 138 小时
- 最后登录
- 2018-11-1
- 注册时间
- 2015-8-26
- 听众数
- 13
- 收听数
- 0
- 能力
- 0 分
- 体力
- 366 点
- 威望
- 0 点
- 阅读权限
- 30
- 积分
- 146
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 70
- 主题
- 23
- 精华
- 0
- 分享
- 0
- 好友
- 17
升级   23% TA的每日心情 | 难过 2016-5-14 14:04 |
|---|
签到天数: 18 天 [LV.4]偶尔看看III
- 自我介绍
- 软件开发工程师
 |
=========================================
* P- ]4 y6 Y R+ p l最短路径中的Floyd算法(弗洛伊德算法)的较为严格的冥想证明过程:) |" S* q- I' I& t b
仍用数学归纳法,8 o l* D( t) ^% A' ^+ c& \( A
假设N<=n时,弗法正确。具体值我就不验证了。8 f! V9 ~; D: b# A; f9 J& l% }+ Q% j$ A
当N=n+1时,假设最新一点最后一点为K,此时K=n+1,9 F! E; _2 }3 o. o3 M* f7 y* C- W
三重循环中,我们都把K排在循环中的最后一位。
6 d: g; R: R+ i% N8 i6 {1 j现在我们要证明的是,加上新点K点后,经过弗法的三重循环,原来的n点之间仍是最短距离,但是n点与K点之间的短离是不是最短的就不知的。
( p+ d, L" k, ~- `* R2 t如果原来的n点的某两点之间最短距是与K点无关的,显然经过三重循环后,就是最短距了。: Y% ^1 I8 R. I- X
如果原来的n点的某两点之间最短距是经过K点的,假设P1,P2,P3,,,Pk-1,Pk,Pk+1,,,Pm本应是实边最短距,不是虚边最短距。! S4 `' X J; j8 t5 o5 O
那么由弗法知,P1,P2,P3,,,Pk-1与PK+1,,,,Pm已是连通的最短路了。且Pk-1Pk与PKPK+1是原始实边,不是虚边。4 I6 P, I; U7 m/ u) ^
经过最外层最后一次循环的松驰操作,必能连通P1,P2,P3,,,Pk-1,Pk,Pk+1,,,Pm。) [5 Z$ p$ O' p6 W
所以得证:加上新点K点后,经过弗法的三重循环,原来的n点之间仍是最短距离,但是n点与K点之间的短离是不是最短的就不知的。8 a1 {$ d6 I* c2 r& S% E! C& M! l
由于对称性,将K点置入内部,把P1点放到最后一点,原来的循环结果不会变的,6 y u! A P5 m- _
所以三重循环后,K点与原来的点(除P1外)的最短距,就可以求出来了。
6 V- f2 k7 N1 q$ G- g4 v由于对称性,将K点置入内部,把P2点放到最后一点,原来的循环结果不会变的,$ ?" b7 N8 H0 H
所以三重循环后,K点与原来的点(除P2外,但P1不除外)的最短距,就可以求出来了。/ T4 U8 D( t8 f1 w- t$ M: j) Z F
所以K点与原来的n个点的最短距,也就已经求出来的了,仍是原来的三重循环也。
z, ^. B/ w+ @: g这样,弗法就可以较为严格的证明了。
+ O, m( ?7 Y* G! Y: T. c; e1 u( D( ]=========================================
8 X9 }) k& T8 ]0 _为何假设P1,P2,P3,,,Pk-1,Pk,Pk+1,,,Pm本应是实边最短距,不是虚边最短距???
7 e; j+ n4 G( z3 u如果是虚边最短距,也可以转化成实边最短距,然后结果一样的。8 ~7 @! ~+ L. I9 A% s
=========================================
1 Y5 i1 b7 N* ~6 G) E3 R
6 v) j! ^% w3 M7 F/ [1 U+ Q' R+ T. K B2 D
|
zan
|