QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 7961|回复: 32
打印 上一主题 下一主题

[问题求助] 最短路径算法的弗洛伊德算法的数学归纳法冥想证明 Version 1.0

[复制链接]
字体大小: 正常 放大
释永思        

23

主题

13

听众

146

积分

升级  23%

  • TA的每日心情
    难过
    2016-5-14 14:04
  • 签到天数: 18 天

    [LV.4]偶尔看看III

    自我介绍
    软件开发工程师

    社区QQ达人

    跳转到指定楼层
    1#
    发表于 2015-9-7 11:12 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    本帖最后由 释永思 于 2015-9-23 16:16 编辑 4 q5 @, ^' h- m( ?" l

    # ]3 h% }4 B& b. K1 f) \最短路径算法的弗洛伊德算法的数学归纳法冥想证明 Version 1.0" d: J) C8 K' M
    & \6 ?4 F* d  ^: w* [" ^* ]
                                    作者:李均宇(李恒星)  2015.09.07
    : q9 S5 j8 G* Q  {
    ! }; k# A7 {8 ?( C, k   我二十年前已了解迪杰斯特拉算法,最近忽有兴趣开发了一款最短路径算法小软件EXE,了却二十年前的心愿。余庆未了,网上了解了还有多种方法,如A-Star,johnson,bellman,SPFA等算法,其中最感兴趣的是弗洛伊德算法。百度了,看了很多源码,大同小异。但对弗洛伊德算法原理,网上讲的,我看后也觉似懂非懂。利用抗战70周年纪念日放假期间,我闭关冥想,想到了N步的方法,但冥想出来的源码,总比网上讲的多一层循环。于是继续冥想,想到了要用数学归纳法来证明弗洛伊德算法。百度下,好似网上暂没这方面资料,于是共享出来,与诸君分享,不知对错也,网上讲到的什么迭代法,总是不太对似的,弗法可能并没有这么简单的:
    ( f3 |; C; N0 L) a0 n假设顶点数为N," X+ B& @# A; d) `3 J0 U6 l
        N=4,5,6时,具体的弗法正确性,我就不想验证了。) n, s+ a% s- ]4 H
    假设N<=n时,弗法是正确的,如何证明N=n+1时,弗法仍是正确的?9 l$ E1 J. I! s9 ^
        先研究下N=n弗法正确时的特性。
    ( u& f" u% V# K0 }5 p" @N=n时,所有的n个顶点两两组合的边D[i,j],不论虚边实边(直接的称实边,要通过其他顶点的叫虚边,我如此定义先),全部有值,且为最小值最短路径。N<n时,也就是最外层循环,每到一个值K时,此值K的弗法全是正确。
    % I% C; s9 P) V8 n当N=n+1时,新加一点,称最后一点K。
    * i  M1 p' ?# m. B+ `- w& O+ o令最后一点K总在循环中排在最后一位,三重循环中都是排在最后一位。# K% f, Z( ^4 o! \6 V3 v: k0 g& v8 D
    令最外层循环为k,中间层循环为j,最内层循环为i。
    5 U/ X- h4 E& g) }定理一:
    6 z0 e1 w3 b: f3 w/ f8 m   最后一点k若改变i与j之距D[i,j],则所有经过i与j之最短路必同步更新且不分先后。
    & F% S/ c3 L4 u: ~证明:
    9 j( o% \) t0 t4 u/ e  假设点x经过最短路径D[i,j],D[i,x]=D[i,j]+D[j,x]或D[i,x]=D[i,j]-D[j,x]。# e. ?  A: u2 W- t" R& c
    D[i,j]已被替换成为了D[i,k]+D[j,k],而D[j,k]+D[j,x]>=D[k,x]或D[j,k]+D[j,x]>=D[k,x].- A! [; }, n$ P3 ^- x0 W$ P
    所以D[i,x]>=D[i,k]+D[k,x],所以x点必被更新,也就是执行松驰操作。
    " V# U" p( q6 n+ R, u+ t, v1 E定理二:- f* A9 Q' h  Z# }! x/ W! ^% l
       最后一点k若改变i与j之距D[i,j],则经过i与j之最短路必不经过最后一点k。
    , O' }7 x: h1 a( a1 g1 a证明:
    ' u, X, Q3 u+ U   由定理一知,如果经过最后一点k,则D[i,k]本身要变,但正是用D[i,k]来执行松驰操作的,所以矛盾。% f# i  j( y2 o) P6 s

    9 [9 h# Q5 c8 E1 v  m定理四:2 W0 {/ r. U; V' l  p8 L
       最后一点k与任一点之连线D[i,k]或D[j,k]必非无穷大,即必已连接(不论虚边实边)。
    2 e2 i4 i5 [3 y" H& n5 l证明:
    ; ^- [/ E' v$ I8 x' g3 Z) c   k为最内层循环点最后一位。取i,j最小者位于中间层循环,最大者位于最外层循环。
    2 L7 p+ T4 e( f' Q此为max(i,j)<n之弗法,弗法已假设N<=n时全成立,现在求证N=n+1时情况。/ z" A" @1 J5 l
    可知i,j必连通,即D[i,j]必非无穷大。4 w' ]8 N+ V( K
    D[i,k],D[j,k]两个不可能都是无穷大,这可以取min(i,j)来递归而知,min迭代到一条实边则可止,或本身数学归纳法内部要嵌套另一个数学归纳法来证明其中小引理。6 e1 h9 P* W/ [/ C7 z
    即知D[i,k],D[j,k]必有一个是连通的,D[i,j]也是连通的,从而三点必全连通,必非无穷大。$ M* C1 X5 Z  j+ T
    定理五:  D: @9 b" n. u1 D3 _& q- W0 t
       与k相连已经全是最短路。
    3 D" E/ v+ u" A5 `+ U3 ^! `) p1 _  O证明:8 t  O6 l! J) W
       因为与最后一点k相连的,全部没有变动,全部已非无穷大,所以经过k点的必是最短路。
    + Q1 c( \# L" d* f# S* d3 m5 m0 M) P' _
    所以新增一点k,由定理五知,当最外层循环到最后一位k时,所有经过k点的已是最短路。/ s3 ^# r* n3 @* n1 k! I
    所有对原来N=n时的弗法最短路的调整松弛操作,全能同步更新经过相关点的最短路,也就是原来的n个点的弗法,后来仍是最短路。
    : `4 }! G) N- F2 V9 Q则N=n+1时,全部三重循环后,全部仍是最短路。
    # L9 F2 \' h" f* k/ \5 ^由数学归纳法知,三重循环的弗洛伊德算法是正确的。
    % M, j4 Q7 Z' A. P7 [% |2 w4 `& E///////////////////////////////////////////////////////////////////////////////////////
    - O- M+ \1 k6 d* A关于弗洛伊德算法的新证明:2015.09.23& J! D: W) o  N. |) H
      _2 M( V& e+ j; n) L; _
    经过弗法的三重循环后,任意两点之间的距离已是最短路。% C1 R; r( b4 L
    仍用数学归纳法,假设N <= n时,弗法是正确的,要证明,N = n+1时,弗法仍是成立的。
    0 C( x+ x9 N7 o6 M. D设k = n+1是最后一点。
    + G# k" N  c0 h& ~如果任意两点间的最短路径结过的顶点数是小于k的,那么根据假设知弗法正确是最短路的。
    + B; `6 O+ f0 g- L6 A  K如果任意两点间的最短路径结过的顶点数是等于k的。那么知摘去最后3个顶点即只剩下(k-3)个点时,是N <= n的情形。2 n1 u( \" q2 z
    起点是a点,终点是b点,与k点直接相连的是c点,d点 。
    7 |) j/ ~; j$ b当最外层第三重循环循环到最后三点k,c,d时,ac,bd已经连通了是N <= n的弗法情形。$ r/ }- f) e. m' o, o
    k,c,d三点,无论哪个是先是后的组合,都必定能够令ab连通且最短路。  H, S& k! H" h8 f% Q
    例如k点连通cd,c点连通ad,d点连通ab。$ E0 L' v: }0 L; H( R- x
    又如c点连通ak(ck不用c点连通,因为原始边长早已有数值早已连通),k点连通ad,d点连通ab。+ E  x7 ^( U# [3 Q4 c
    所以命题得证。
    2 W; g  V/ H1 h9 J& g8 @9 u; G- ~
    # w1 m3 O( y' y. k6 x, a$ K) v( B4 [% ]5 V2 I5 S  K* T

    . K5 y& V+ H- `1 H2 r- h1 I8 ~" q9 U% o5 d

    5 f/ Z+ n1 W& i, o+ X+ r) u0 U) T8 L3 d' }6 h" }
    : \2 ~+ w3 ?* e1 N

    6 E% c% s2 ~! `# q9 b* s+ ~( S, z

    2 }# B4 q9 S2 c2 F4 T4 {+ P% S( t- U+ o
    ( i, C, r  m4 P7 m1 T8 I) D

    0 w7 P- \$ g0 ~( j! B0 ^9 E# _4 h9 A# `# H+ n" Z

    . D& n; S7 K$ E) c' T
    ( q0 ?* p% U4 d1 d  `1 H% G! j- b  Y: @+ W4 f: G: M& I. L. d# w
    % v+ \9 q( V  c
    / X) e7 z% F% m! b# e/ X/ N
    ' Z- }5 {4 L  X- o  r/ e6 m
    & T$ V7 F+ T; }" K; r% x' Z
    # T3 j: _. h+ [: x/ H+ h0 z
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    361

    主题

    13

    听众

    2078

    积分

    风靡全球

  • TA的每日心情
    开心
    2016-11-15 12:14
  • 签到天数: 102 天

    [LV.6]常住居民II

    网络挑战赛参赛者

    新人进步奖 发帖功臣 最具活力勋章

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-17 04:04 , Processed in 0.804144 second(s), 97 queries .

    回顶部