日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

单源最短路SPFA

發布時間:2023/12/19 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 单源最短路SPFA 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

單源最短路SPFA

算法思想:

將遍歷到且滿足條件的點加入隊列中,如果遍歷到的點在隊列,就不加入。

對每個結點進行遍歷時,更改其是否在隊列的狀態。

在隊列內即為true

若不在隊列內且其值被更改,則加入隊列

  • if(minx[s,t]>minx[s,k]+minx[k,t])
  • minx[s][t]=minx[s,k]+minx[k,t] if(st==false){st=trueq.push(t) }

    每次更新一個點的最小值后,才加入隊列,借更新的值更新其他點。

    若不更新,則不必加入隊列。

    此外有多種優化方式,最簡單的就是SLF優化,將小權值的點加入隊列最前方,對于數據量小的情況時間優化不大。

    因此時3在隊列中,因此其無法從負環計算

    當4出隊列,3進行遍歷,則可進行對負數查找,隨后將4與2加入隊列,又遍歷2

    若存在負環,則負環值永遠無法累加

    而因更新值時才會加入隊列,因此不存在跳不出循環的情況

    例題:

    代碼如下:

    #include<iostream> #include<algorithm> #include<string.h> #include<stdio.h> #include<string> #include<queue> #include<stack> #include<vector>using namespace std;int n, m; int a, b, c; vector<int> sic[1005]; int bq[1005][1005]; bool st[1005]; int ans[1005];void SPFA() {queue<int>q;q.emplace(1);memset(ans, 0x3f, sizeof ans);st[1] = 1;ans[1] = 0;while (!q.empty()) {int k = q.front();q.pop();st[k] = 0;//將移除隊列的結點拿出for (auto x : sic[k]) {if (ans[x] > ans[k] + bq[k][x]) {ans[x] = ans[k] + bq[k][x];//更新權值if (!st[x]) {q.push(x);//將不再隊列中的滿足條件的加入隊列st[x] = 1;}}}} }int main() {while (cin >> m >> n, n != 0 && m != 0) {memset(bq, 0, sizeof bq);memset(st, 0, sizeof st);memset(sic, 0, sizeof sic);for (int i = 0; i < n; i++) {cin >> a >> b >> c;sic[a].push_back(b);sic[b].push_back(a);bq[a][b] = bq[b][a] = c;}SPFA();cout << ans[m] << endl;}return 0; }

    此題目加入SLF優化后時間變化不大,代碼如下:

    #include<iostream> #include<algorithm> #include<string.h> #include<stdio.h> #include<string> #include<queue> #include<stack> #include<vector>using namespace std;int n, m; int a, b, c; vector<int> sic[1005]; int bq[1005][1005]; bool st[1005]; int ans[1005];void SPFA() {deque<int>q;q.emplace_back(1);memset(ans, 0x3f, sizeof ans);st[1] = 1;ans[1] = 0;while (!q.empty()) {int k = q.front();q.pop_front();st[k] = 0;for (auto x : sic[k]) {if (ans[x] > ans[k] + bq[k][x]) {ans[x] = ans[k] + bq[k][x];if (!st[x]) {if (!q.empty()) {//不為空,則進行判斷對比if (ans[x] > ans[q.front()])q.emplace_front(x);elseq.emplace_back(x);}else {q.emplace_back(x);}st[x] = 1;}}}} }int main() {while (cin >> m >> n, n != 0 && m != 0) {memset(bq, 0, sizeof bq);memset(st, 0, sizeof st);memset(sic, 0, sizeof sic);for (int i = 0; i < n; i++) {cin >> a >> b >> c;sic[a].push_back(b);sic[b].push_back(a);bq[a][b] = bq[b][a] = c;}SPFA();cout << ans[m] << endl;}return 0; }

    總結

    以上是生活随笔為你收集整理的单源最短路SPFA的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 美女又黄又免费的视频 | 欧美成人精品激情在线观看 | 欧美激情图区 | 国产又猛又黄 | 福利视频在线免费观看 | 日韩欧美在线第一页 | 日韩精品乱码 | av直接看| 欧美色图日韩 | 日韩欧美自拍 | 懂色一区二区二区av免费观看 | 青青草原综合久久大伊人精品 | а√天堂8资源中文在线 | 快播怡红院 | 调教亲女小嫩苞h文小说 | 国产一二三区在线 | 欧美xx在线 | 日日干夜夜骑 | 日韩精彩视频 | 国产成人综合亚洲 | 女人囗交吞精囗述 | 精品亚洲永久免费精品 | 30一40一50老女人毛片 | 美国一级片网站 | 久久偷看各类wc女厕嘘嘘偷窃 | 性欧美free| www青青草| 日韩三级麻豆 | 五月婷婷婷婷 | 免费在线观看日韩 | 中文av一区二区三区 | 黄色精品在线观看 | 日本在线免费观看视频 | 欧美一级特黄视频 | 经典杯子蛋糕日剧在线观看免费 | 午夜黄色av | 中文字幕日韩欧美 | aaaaaav| 成人免费网站在线 | 做暧暧视频在线观看 | 在线一区av | 亚洲av成人精品日韩在线播放 | 亚洲自拍偷拍区 | 天天干天天干天天干天天 | 亚洲91久久| 生活片av | 中文字幕av影视 | 欧美在线视频你懂的 | 成人污 | 亚洲欧美高清在线 | 白丝动漫美女 | 欧美日韩不卡合集视频 | 国产乱叫456在线 | 欧美成人综合网站 | www日韩在线观看 | 国产又爽又黄无码无遮挡在线观看 | 今天高清视频在线观看视频 | 免费观看亚洲 | 极品国产一区 | 男男啪啪网站 | 欧美一级色片 | 国产私拍 | 亚洲视频在线免费观看 | 成人自拍视频在线观看 | 免费无码国产v片在线观看 三级全黄做爰在线观看 | 91av视频在线 | 四虎一区二区三区 | 1024亚洲天堂| 国产激情久久久久久熟女老人av | 日本少妇ⅹxxxxx视频 | 91片看| 性大片潘金莲裸体 | 日韩一区二区精品视频 | 神马一区二区三区 | 伊人久久大香线 | 成人免费视频国产免费 | 91狠狠综合 | 97超碰福利 | av网站在线观看不卡 | 在线观看免费av网址 | 国产又色又爽又黄又免费 | 领导揉我胸亲奶揉下面 | 野花av | 日韩一级二级 | 少妇精品无码一区二区免费视频 | 国产成人在线看 | 99re最新 | 99久久99久久精品国产片 | 激烈的性高湖波多野结衣 | 亚洲精品18在线观看 | 亚洲av无码成人精品区 | 久久艹中文字幕 | 久久久久99精品成人片 | 久久9精品区-无套内射无码 | 97超碰成人 | 亚洲一二区| 亚洲一区二区三区在线免费观看 | 欧美成人午夜精品免费 | 热久久91 |