{"id":2983,"date":"2022-03-24T16:50:50","date_gmt":"2022-03-24T08:50:50","guid":{"rendered":"http:\/\/139.9.1.231\/?p=2983"},"modified":"2022-03-24T16:50:52","modified_gmt":"2022-03-24T08:50:52","slug":"bellman-ford","status":"publish","type":"post","link":"http:\/\/139.9.1.231\/index.php\/2022\/03\/24\/bellman-ford\/","title":{"rendered":"Bellman-Ford \u5355\u6e90\u6700\u77ed\u8def\u5f84\uff08\u56de\u8def\uff09\u7b97\u6cd5"},"content":{"rendered":"\n<p>Bellman-ford \u7b97\u6cd5\u6bd4dijkstra\u7b97\u6cd5\u66f4\u5177\u666e\u904d\u6027\uff0c\u56e0\u4e3a\u5b83\u5bf9\u8fb9\u6ca1\u6709\u8981\u6c42\uff0c\u53ef\u4ee5\u5904\u7406\u8d1f\u6743\u8fb9\u4e0e\u8d1f\u6743\u56de\u8def\u3002\u7f3a\u70b9\u662f\u65f6\u95f4\u590d\u6742\u5ea6\u8fc7\u9ad8\uff0c\u9ad8\u8fbeO(VE), V\u4e3a\u9876\u70b9\u6570\uff0cE\u4e3a\u8fb9\u6570\u3002<\/p>\n\n\n\n<p class=\"has-light-pink-background-color has-background\">\u7279\u70b9\uff1a<strong>\u652f\u6301\u6709\u73af\uff0c\u8d1f\u6743\u91cd\uff0c\u4f46\u4e0d\u80fd\u5b58\u5728\u8d1f\u6743\u91cd\u73af<\/strong>\u3002<\/p>\n\n\n\n<p>\u5176\u4e3b\u8981\u601d\u60f3\uff1a\u5bf9\u6240\u6709\u7684\u8fb9\u8fdb\u884cn-1\u8f6e\u677e\u5f1b\u64cd\u4f5c\uff0c\u56e0\u4e3a\u5728\u4e00\u4e2a\u542b\u6709n\u4e2a\u9876\u70b9\u7684\u56fe\u4e2d\uff0c\u4efb\u610f\u4e24\u70b9\u4e4b\u95f4\u7684\u6700\u77ed\u8def\u5f84\u6700\u591a\u5305\u542bn-1\u8fb9\u3002\u6362\u53e5\u8bdd\u8bf4\uff0c\u7b2c1\u8f6e\u5728\u5bf9\u6240\u6709\u7684\u8fb9\u8fdb\u884c\u677e\u5f1b\u540e\uff0c\u5f97\u5230\u7684\u662f\u6e90\u70b9\u6700\u591a\u7ecf\u8fc7\u4e00\u6761\u8fb9\u5230\u8fbe\u5176\u4ed6\u9876\u70b9\u7684\u6700\u77ed\u8ddd\u79bb\uff1b\u7b2c2\u8f6e\u5728\u5bf9\u6240\u6709\u7684\u8fb9\u8fdb\u884c\u677e\u5f1b\u540e\uff0c\u5f97\u5230\u7684\u662f\u6e90\u70b9\u6700\u591a\u7ecf\u8fc7\u4e24\u6761\u8fb9\u5230\u8fbe\u5176\u4ed6\u9876\u70b9\u7684\u6700\u77ed\u8ddd\u79bb\uff1b\u7b2c3\u8f6e\u5728\u5bf9\u6240\u6709\u7684\u8fb9\u8fdb\u884c\u677e\u5f1b\u540e\uff0c\u5f97\u5230\u7684\u662f\u6e90\u70b9\u6700\u591a\u7ecf\u8fc7\u4e00\u6761\u8fb9\u5230\u8fbe\u5176\u4ed6\u9876\u70b9\u7684\u6700\u77ed\u8ddd\u79bb&#8230;&#8230;<\/p>\n\n\n\n<p>Bellman-Ford&nbsp;\u7b97\u6cd5\u63cf\u8ff0\uff1a<\/p>\n\n\n\n<ol><li>\u521b\u5efa\u6e90\u9876\u70b9 v \u5230\u56fe\u4e2d\u6240\u6709\u9876\u70b9\u7684\u8ddd\u79bb\u7684\u96c6\u5408 distSet\uff0c\u4e3a\u56fe\u4e2d\u7684\u6240\u6709\u9876\u70b9\u6307\u5b9a\u4e00\u4e2a\u8ddd\u79bb\u503c\uff0c\u521d\u59cb\u5747\u4e3a Infinite\uff0c\u6e90\u9876\u70b9\u8ddd\u79bb\u4e3a 0\uff1b<\/li><li>\u8ba1\u7b97\u6700\u77ed\u8def\u5f84\uff0c\u6267\u884c V &#8211; 1 \u6b21\u904d\u5386\uff1b<ul><li>\u5bf9\u4e8e\u56fe\u4e2d\u7684\u6bcf\u6761\u8fb9\uff1a\u5982\u679c\u8d77\u70b9 u \u7684\u8ddd\u79bb d \u52a0\u4e0a\u8fb9\u7684\u6743\u503c w \u5c0f\u4e8e\u7ec8\u70b9 v \u7684\u8ddd\u79bb d\uff0c\u5219\u66f4\u65b0\u7ec8\u70b9 v \u7684\u8ddd\u79bb\u503c d\uff1b<\/li><\/ul><\/li><li>\u68c0\u6d4b\u56fe\u4e2d\u662f\u5426\u6709\u8d1f\u6743\u8fb9\u5f62\u6210\u4e86\u73af\uff0c\u904d\u5386\u56fe\u4e2d\u7684\u6240\u6709\u8fb9\uff0c\u8ba1\u7b97 u \u81f3 v \u7684\u8ddd\u79bb\uff0c\u5982\u679c\u5bf9\u4e8e v \u5b58\u5728\u66f4\u5c0f\u7684\u8ddd\u79bb\uff0c\u5219\u8bf4\u660e\u5b58\u5728\u73af\uff1b<\/li><\/ol>\n\n\n\n<pre class=\"wp-block-code\"><code>for (var i = 0; i &lt; n - 1; i++) {\r\n    for (var j = 0; j &lt; m; j++) {\/\/\u5bf9m\u6761\u8fb9\u8fdb\u884c\u5faa\u73af\r\n      var edge = edges&#91;j];\r\n      \/\/ \u677e\u5f1b\u64cd\u4f5c\r\n      if (distance&#91;edge.to] > distance&#91;edge.from] + edge.weight ){ \r\n        distance&#91;edge.to] = distance&#91;edge.from] + edge.weight;\r\n      }\r\n    }\r\n}<\/code><\/pre>\n\n\n\n<p>\u5176\u4e2d\uff0c n\u4e3a\u9876\u70b9\u7684\u4e2a\u6570\uff0cm\u4e3a\u8fb9\u7684\u4e2a\u6570\uff0cedges\u6570\u7ec4\u50a8\u5b58\u4e86\u6240\u6709\u8fb9\uff0cdistance\u6570\u7ec4\u662f\u6e90\u70b9\u5230\u6240\u6709\u70b9\u7684\u8ddd\u79bb\u4f30\u8ba1\u503c\uff0c\u5faa\u73af\u7ed3\u675f\u540e\u5c31\u662f\u6700\u5c0f\u503c\u3002<\/p>\n\n\n\n<p class=\"has-light-pink-background-color has-background\">\u7b97\u6cd5\u8fc7\u7a0b\uff1a\u9996\u5148\u521d\u59cb\u5316\uff0c\u5bf9\u6240\u6709\u7684\u8282\u70b9V\u6765\u8bf4\uff0c\u6240\u6709\u7684\u8fb9E\u8fdb\u884c\u677e\u5f1b\u64cd\u4f5c\uff0c\u518d\u7136\u540e\u5faa\u73af<a href=\"https:\/\/so.csdn.net\/so\/search?q=%E9%81%8D%E5%8E%86&amp;spm=1001.2101.3001.7020\" target=\"_blank\" rel=\"noreferrer noopener\">\u904d\u5386<\/a>\u6bcf\u6761\u8fb9\uff0c\u5982\u679cd[v] &gt; d[u] + w(u,v),\u8868\u793a\u6709\u4e00\u4e2a\u8d1f\u6743\u91cd\u7684\u73af\u8def\u5b58\u5728\u3002<\/p>\n\n\n\n<p class=\"has-light-pink-background-color has-background\">\u00a0\u6700\u540e\u5982\u679c\u6ca1\u6709\u8d1f\u6743\u91cd\u73af\u8def\uff0c\u90a3\u4e48d[v] \u662f\u6700\u5c0f\u8def\u5f84\u503c\u3002<\/p>\n\n\n\n<p>python \u5b9e\u73b0\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\r\ndef bellman_ford(graph, source):\r\n    dist = {}\r\n    p = {}\r\n    max = 10000\r\n    for v in graph:\r\n        dist&#91;v] = max  #\u8d4b\u503c\u4e3a\u8d1f\u65e0\u7a77\u5b8c\u6210\u521d\u59cb\u5316\r\n        p&#91;v] = None\r\n    dist&#91;source] = 0\r\n \r\n    for i in range(len( graph ) - 1):\r\n        for u in graph:\r\n            for v in graph&#91;u]:\r\n                if dist&#91;v] > graph&#91;u]&#91;v] + dist&#91;u]:\r\n                    dist&#91;v] = graph&#91;u]&#91;v] + dist&#91;u]\r\n                    p&#91;v] = u    #\u5b8c\u6210\u677e\u5f1b\u64cd\u4f5c\uff0cp\u4e3a\u524d\u9a71\u8282\u70b9\r\n \r\n    for u in graph:\r\n        for v in graph&#91;u]:\r\n            if dist&#91;v] > dist&#91;u] + graph&#91;u]&#91;v]:\r\n                return None, None  #\u5224\u65ad\u662f\u5426\u5b58\u5728\u73af\u8def\r\n \r\n    return dist, p\r\n \r\ndef test():\r\n    graph = {\r\n        'a': {'b': -1, 'c':  4},\r\n        'b': {'c':  2, 'd':  3, 'e':  2},\r\n        'c': {},\r\n        'd': {'b':  3, 'c':  5},\r\n        'e': {'d': -3}\r\n    }\r\n    dist, p = bellman_ford(graph, 'a')\r\n    print(dist)\r\n    print(p)\r\ndef testfail():\r\n    graph = {\r\n        'a': {'b': -1, 'c':  4},\r\n        'b': {'c':  2, 'd':  3, 'e':  2},\r\n        'c': {'d': -5},\r\n        'd': {'b':  3},\r\n        'e': {'d': -3}\r\n    }\r\n    dist, p = bellman_ford(graph, 'a')\r\n    print(dist)\r\n    print(p)\r\n \r\ntest()\r\ntestfail()<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>Bellman-ford \u7b97\u6cd5\u6bd4dijkstra\u7b97\u6cd5\u66f4\u5177\u666e\u904d\u6027\uff0c\u56e0\u4e3a\u5b83\u5bf9\u8fb9\u6ca1\u6709\u8981\u6c42\uff0c\u53ef\u4ee5\u5904\u7406\u8d1f\u6743\u8fb9\u4e0e\u8d1f\u6743\u56de\u8def\u3002 &hellip; <a href=\"http:\/\/139.9.1.231\/index.php\/2022\/03\/24\/bellman-ford\/\" class=\"more-link\">\u7ee7\u7eed\u9605\u8bfb<span class=\"screen-reader-text\">Bellman-Ford \u5355\u6e90\u6700\u77ed\u8def\u5f84\uff08\u56de\u8def\uff09\u7b97\u6cd5<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[6,8],"tags":[],"_links":{"self":[{"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/posts\/2983"}],"collection":[{"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/comments?post=2983"}],"version-history":[{"count":8,"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/posts\/2983\/revisions"}],"predecessor-version":[{"id":3023,"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/posts\/2983\/revisions\/3023"}],"wp:attachment":[{"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/media?parent=2983"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/categories?post=2983"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/139.9.1.231\/index.php\/wp-json\/wp\/v2\/tags?post=2983"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}