QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8148|回复: 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 编辑 9 P% s$ w' S- e: V; b
    4 r; b% t+ S# H' `2 e/ j/ ?* J
    最短路径算法的弗洛伊德算法的数学归纳法冥想证明 Version 1.0; N. ?* M' E- S2 a

    2 b$ o" q2 z, T5 x1 g                                作者:李均宇(李恒星)  2015.09.07
    ) Q- j$ l. L! q& u! `& Y; B
    ! I) G: D# i. p# \7 ^& ?. e   我二十年前已了解迪杰斯特拉算法,最近忽有兴趣开发了一款最短路径算法小软件EXE,了却二十年前的心愿。余庆未了,网上了解了还有多种方法,如A-Star,johnson,bellman,SPFA等算法,其中最感兴趣的是弗洛伊德算法。百度了,看了很多源码,大同小异。但对弗洛伊德算法原理,网上讲的,我看后也觉似懂非懂。利用抗战70周年纪念日放假期间,我闭关冥想,想到了N步的方法,但冥想出来的源码,总比网上讲的多一层循环。于是继续冥想,想到了要用数学归纳法来证明弗洛伊德算法。百度下,好似网上暂没这方面资料,于是共享出来,与诸君分享,不知对错也,网上讲到的什么迭代法,总是不太对似的,弗法可能并没有这么简单的:
    + W; B- @2 x3 F# B& ^假设顶点数为N,& J2 F. X: |, _
        N=4,5,6时,具体的弗法正确性,我就不想验证了。. S1 w$ c+ }) R) u% h; A/ e
    假设N<=n时,弗法是正确的,如何证明N=n+1时,弗法仍是正确的?
    & f& Q9 n" m6 |- u( v    先研究下N=n弗法正确时的特性。
    8 y! |& D7 q; t3 I; X; n7 YN=n时,所有的n个顶点两两组合的边D[i,j],不论虚边实边(直接的称实边,要通过其他顶点的叫虚边,我如此定义先),全部有值,且为最小值最短路径。N<n时,也就是最外层循环,每到一个值K时,此值K的弗法全是正确。
    1 {' L8 R/ e$ M3 }0 q' `当N=n+1时,新加一点,称最后一点K。% y2 h( g3 \7 b7 K/ Y
    令最后一点K总在循环中排在最后一位,三重循环中都是排在最后一位。9 o3 ^) f. \' l* P! R4 {/ }9 l( r
    令最外层循环为k,中间层循环为j,最内层循环为i。
    , ?% N1 O5 ^! s, }. u! P定理一:
    - g1 t  m  t  i1 O" L# R   最后一点k若改变i与j之距D[i,j],则所有经过i与j之最短路必同步更新且不分先后。1 b: u  E( e4 v1 b% T
    证明:4 N  u9 W0 k/ n! H7 r! l
      假设点x经过最短路径D[i,j],D[i,x]=D[i,j]+D[j,x]或D[i,x]=D[i,j]-D[j,x]。& }4 u% A6 \8 S7 U: a
    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].: s# R8 f6 A6 ?' d
    所以D[i,x]>=D[i,k]+D[k,x],所以x点必被更新,也就是执行松驰操作。
    - p( Y' d" |5 |- ]  B定理二:; B, u6 l& Z# k0 ~1 E- D
       最后一点k若改变i与j之距D[i,j],则经过i与j之最短路必不经过最后一点k。
    ( M9 @/ |9 F5 O; |! z- S* c, f证明:
    : i: T0 {# f; _& j   由定理一知,如果经过最后一点k,则D[i,k]本身要变,但正是用D[i,k]来执行松驰操作的,所以矛盾。
    ' V4 T: `' B* R0 W
    ' \: ^- X3 R' @' q* e5 t定理四:
    7 O9 F' L8 T  X2 R( G4 H# O; s; j6 x* @   最后一点k与任一点之连线D[i,k]或D[j,k]必非无穷大,即必已连接(不论虚边实边)。
    7 M' {, i! `5 f6 J: X5 u6 i2 a证明:
    " s2 m& I" s# p# Y( |9 I, E   k为最内层循环点最后一位。取i,j最小者位于中间层循环,最大者位于最外层循环。
    . X3 H1 N) n: h此为max(i,j)<n之弗法,弗法已假设N<=n时全成立,现在求证N=n+1时情况。( A+ u0 K( H  _$ E' Z
    可知i,j必连通,即D[i,j]必非无穷大。1 L9 E: m6 c+ o  x' a5 {( n% f
    D[i,k],D[j,k]两个不可能都是无穷大,这可以取min(i,j)来递归而知,min迭代到一条实边则可止,或本身数学归纳法内部要嵌套另一个数学归纳法来证明其中小引理。
    ) k7 G: `' T- l( q& C. E即知D[i,k],D[j,k]必有一个是连通的,D[i,j]也是连通的,从而三点必全连通,必非无穷大。
    & U8 n2 R; g6 l( A( v, S定理五:/ A2 ]3 t3 B" j
       与k相连已经全是最短路。
    8 Z0 ]& \; V* B3 _* i证明:; h# |' |6 m7 e
       因为与最后一点k相连的,全部没有变动,全部已非无穷大,所以经过k点的必是最短路。4 W9 A7 u2 `  k" o2 D" @

    , k! \  b9 J$ O* l& p1 r所以新增一点k,由定理五知,当最外层循环到最后一位k时,所有经过k点的已是最短路。
    9 o' R" w9 j9 m% i所有对原来N=n时的弗法最短路的调整松弛操作,全能同步更新经过相关点的最短路,也就是原来的n个点的弗法,后来仍是最短路。5 _) v/ X# f' v1 t( \  ~1 O7 ]0 w
    则N=n+1时,全部三重循环后,全部仍是最短路。
    ; q0 Z; ?+ N6 R5 ?5 t由数学归纳法知,三重循环的弗洛伊德算法是正确的。
    . V! k( p  O: G' c' B9 q! G' n///////////////////////////////////////////////////////////////////////////////////////
    ; r: O5 E, T  A: y8 H* F8 \关于弗洛伊德算法的新证明:2015.09.23
    1 ~$ \6 a- ]9 G9 B' M
    8 O9 J) G/ E: O# @& w8 g4 [  i经过弗法的三重循环后,任意两点之间的距离已是最短路。
    0 c+ l9 X1 G8 h" [0 `2 |% w- [# Y6 U仍用数学归纳法,假设N <= n时,弗法是正确的,要证明,N = n+1时,弗法仍是成立的。4 s# {* X! b( g) @" H4 g/ I
    设k = n+1是最后一点。
    " ]- V# I/ w. \1 R如果任意两点间的最短路径结过的顶点数是小于k的,那么根据假设知弗法正确是最短路的。
    7 `/ i9 `& B7 w0 s, W- a' l/ D% J" [如果任意两点间的最短路径结过的顶点数是等于k的。那么知摘去最后3个顶点即只剩下(k-3)个点时,是N <= n的情形。( d- `2 i5 n1 a% q+ u! {# h( ~% y
    起点是a点,终点是b点,与k点直接相连的是c点,d点 。* V/ R9 n/ ^" l$ c
    当最外层第三重循环循环到最后三点k,c,d时,ac,bd已经连通了是N <= n的弗法情形。
    5 C$ E  k( A0 R8 I& D! fk,c,d三点,无论哪个是先是后的组合,都必定能够令ab连通且最短路。
    9 G' P, i8 W4 @4 d% ]# t例如k点连通cd,c点连通ad,d点连通ab。0 S) Z6 z; ]$ Z5 V3 O$ c
    又如c点连通ak(ck不用c点连通,因为原始边长早已有数值早已连通),k点连通ad,d点连通ab。$ f, d1 E9 P. d1 J! O! o1 g
    所以命题得证。
    ! K( P" F/ \) A' r6 ~9 x2 e2 o* W
    , T. ^$ v: U# `2 K+ e; e' b* g$ s1 `7 m

    $ H. C$ N7 v  h$ w/ Z& v
    4 y' b5 j! s# ~% _: c! y/ y. E- e* S# _7 g. l

    , f% A+ ^: X2 n; g6 Z0 k  y& Q
    * v" u* F* x& {
    0 }7 r2 L2 \: e& N( J1 s- H2 j# D& k* v4 ]7 ^. x
    9 f. Y- d/ @3 V7 ]
    9 N5 B! w; [8 w! J6 T/ }& B+ A

    ) s' {3 ?, |5 i5 v( [; W, t1 e
    # r- k  f' d, X& M1 m. i0 G* K: E4 ?$ [- D: j
    . B: g. V  {1 J. G, `/ E9 K
    0 k) i7 b0 s# ?. X
    % I& I" p8 l) S. O) p" ~
    $ Y2 ?: ?& @  k' X" t; l* y8 k

    & ?0 A: ~# v! j+ T0 p' t4 C
    ' y' h; R- u2 l* Q& @1 Z( s( D* {
    ) I$ R# l3 Z& x5 U7 _* b3 a4 V
    5 D% c+ r3 v' ^- v* C
    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-6-7 08:34 , Processed in 0.481652 second(s), 97 queries .

    回顶部