亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言求解無向圖頂點之間的所有最短路徑

2020-01-26 13:33:49
字體:
來源:轉載
供稿:網友

本文實例為大家分享了C語言求解無向圖頂點之間的所有最短路徑的具體代碼,供大家參考,具體內容如下

思路一:

DFS,遇到終點之后進行記錄
輔助存儲:

std::vector<int> tempPath;std::vector<std::vector<int>> totalPath;

實現:

//查找無向圖的所有最短路徑,直接dfs就可以解決了//記錄保存這里用 vector<vector<int>> 插入失敗,重新搞一下 OK// 時間復雜度 O(N + E)#include <iostream>#include <cstdio>#include <cstdlib>#include <vector>#include <set>#define MAX 10#define INF 999999int graph[MAX + 1][MAX + 1];int N, M;          //node, edgeint nodeBook[MAX + 1];int minPath = INF;std::vector<int> pathNodeVec;std::vector<std::vector<int>> allShortVec;int startNode, endNode;void dfs(int i, int step){  if (i == endNode) {   //遇到終點,進行路徑判定    if (step < minPath) {      std::cout << "step < minpath.., size = " << allShortVec.size() << std::endl;      minPath = step;      pathNodeVec.push_back(i);      for (auto &elem : pathNodeVec)        std::cout << elem << "/t";      std::cout << std::endl;      std::vector<int> tempVec = pathNodeVec;      allShortVec.clear();            //清空      allShortVec.push_back(tempVec);      //存儲      pathNodeVec.pop_back();    } else if (step == minPath) {      std::cout << "step == minpath.., size = " << allShortVec.size() << std::endl;      pathNodeVec.push_back(i);      for (auto &elem : pathNodeVec)        std::cout << elem << "/t";      std::cout << std::endl;      std::vector<int> tempVec = pathNodeVec;      allShortVec.push_back(tempVec);     //存儲當前路徑       pathNodeVec.pop_back();    } else { ;}    return;  }  nodeBook[i] = 1;  pathNodeVec.push_back(i);  for (int x = 1; x <= N; x++) {   //嘗試所有可能性    if (x == i)      continue;    if (nodeBook[x] == 1)      continue;    if (graph[i][x] == INF)      continue;    dfs(x, step + 1);  }  nodeBook[i] = 0;  pathNodeVec.pop_back();  return ;}int main(void){  std::cin >> N >> M;  for (int x = 1; x <= N; x++)    nodeBook[x] = 0;    //表示還沒有訪問  for (int x = 1; x <= N; ++x)    for (int y = 1; y <= N; ++y) {      if (x == y)        graph[x][y] = 0;      else        graph[x][y] = INF;    }  for (int i = 1; i <= M; ++i) {    int tempX, tempY, tempWeight;    std::cin >> tempX >> tempY >> tempWeight;    graph[tempX][tempY] = tempWeight;  }  std::cout << "please input start node & end node :" << std::endl;  std::cin >> startNode >> endNode;  pathNodeVec.clear();  allShortVec.clear();  dfs(startNode, 0);  std::cout << "all shortest path: /t";  std::cout << "size = " << allShortVec.size() << std::endl;  for (std::vector<std::vector<int>>::const_iterator it = allShortVec.begin(); it != allShortVec.end(); it++) {    for (std::vector<int>::const_iterator it2 = (*it).begin(); it2 != (*it).end(); it2++)      std::cout << (*it2) << "/t";    std::cout << std::endl;  }  getchar();  return 0;}

時間分析:

O(V + E)

缺點:

可能會爆棧,我這里算86W點+414W邊直接爆,小的沒問題。

思路二:

BFS,位圖/vector/.. 記錄好每一步的路徑即可

時間

O(V + E)

額外開銷:

存儲每一步的路徑,如何維護好,盡量避免循環查找。

思路三:

1. 先求出起始點start到其余所有點的最短路徑;  Dijkstra
2. 然后以終點end為開始,反向進行dfs/bfs搜索;  
每回退 i 層,判斷值(path-i)與起點到當前點最短路徑長度 temp 的比較;
二者相等,則繼續(利用子問題的正確性); 若 (path-i) < temp ,則這個點不在最短路徑上,放棄。

如圖所示:


先求出start到其余所有點的最短路徑;

然后從 end 點開始往回搜索;

end上面一個點,(path - 1 = 3)等于起始點到它的最短路徑長 3,判斷,是最短路徑上的點,繼續;

再往上搜索:

左邊那個點3,因為此時(path - 2)= 2,而那個點的 temp=3,即 (path - i) < temp ,因此那個點一定不在 start 到 end 的最短路徑上。
而上面那個點2,此時 (path - 2)= 2 , 而那個點 temp = 2, 即 (path - i) == temp , 因此它必然在 start 到 end 的最短路徑上。繼續搜索下去 。

重復這樣的過程直到搜索完畢,最終得到兩條最短路徑。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美一乱一性一交一视频| 国产精品久久91| 国产精品美女av| 精品视频久久久久久久| 久久久久久com| 欧美中文在线字幕| 国产精品99久久久久久www| 91热精品视频| 精品国产91乱高清在线观看| 九九热视频这里只有精品| 欧美日韩第一页| 青青草国产精品一区二区| 亚洲va欧美va国产综合久久| 88国产精品欧美一区二区三区| 国产乱肥老妇国产一区二| 日韩中文字幕视频在线观看| 亚洲图片欧美日产| 日韩少妇与小伙激情| 久久九九免费视频| 成人国产精品日本在线| 97超级碰在线看视频免费在线看| 久久久亚洲精品视频| 精品视频在线播放色网色视频| 欧美激情视频免费观看| 精品调教chinesegay| 国产欧美中文字幕| 麻豆乱码国产一区二区三区| 91久久久久久久久久久| 成人激情在线观看| 日韩精品免费在线播放| 成人免费激情视频| 精品久久久999| 日本欧美国产在线| 成人啪啪免费看| 国产69精品久久久久9| 国产精品白嫩美女在线观看| 亚洲色图色老头| 一区二区三区国产视频| 欧美激情乱人伦| 国产有码在线一区二区视频| 色阁综合伊人av| 亚洲综合在线中文字幕| 亚洲第一视频网站| 精品国产乱码久久久久久虫虫漫画| 亚洲精品日韩久久久| 国产精品久久久久久亚洲影视| 亚洲精品短视频| 精品国产自在精品国产浪潮| 欧美国产日韩二区| 国产亚洲精品日韩| 清纯唯美亚洲激情| 欧美人交a欧美精品| 亚洲国产一区二区三区四区| 国产精品久久久久免费a∨大胸| 最近更新的2019中文字幕| 亚洲激情在线视频| 亚洲国产另类 国产精品国产免费| 中文字幕日韩综合av| 亚洲免费视频观看| 欧美老少做受xxxx高潮| 国产精品电影一区| 国产精品极品美女在线观看免费| 日韩免费av一区二区| 在线观看欧美视频| 亚洲福利视频在线| 亚洲欧美精品suv| 午夜精品久久久久久久久久久久| 亚洲九九九在线观看| 久久久久久999| 日韩电影中文字幕av| 久久久精品视频成人| 亚洲欧洲国产一区| 精品日本高清在线播放| 精品视频在线播放免| 亚洲欧洲成视频免费观看| 亚洲最大的av网站| 国产午夜精品美女视频明星a级| 中文在线不卡视频| 久热精品在线视频| 中文字幕一区二区精品| 日韩久久午夜影院| 亚洲第一色中文字幕| 91精品久久久久久久久久| 日韩成人小视频| 色妞欧美日韩在线| 91精品视频观看| 日韩经典第一页| 91在线观看免费观看| 亚洲欧洲中文天堂| 欧美www在线| 欧美激情精品久久久久久大尺度| 久久久久久久一区二区| 国产精品自产拍在线观看中文| 日韩av成人在线观看| 茄子视频成人在线| 精品国产依人香蕉在线精品| 午夜精品久久久久久久99热| 国产91精品不卡视频| 91精品久久久久久久久久另类| 日韩欧美aⅴ综合网站发布| 精品国模在线视频| 福利精品视频在线| 成人做爽爽免费视频| 最近中文字幕mv在线一区二区三区四区| 欧美精品一区在线播放| 欧美国产日本高清在线| 精品国产乱码久久久久久天美| 日韩欧美在线视频| 国产一区二区三区在线观看网站| 中文字幕在线观看日韩| 亚洲另类欧美自拍| 热99精品里视频精品| 久久精品这里热有精品| 亚洲欧美精品在线| 伊人精品在线观看| 91精品视频观看| 一区二区三区回区在观看免费视频| 欧美日韩国产成人高清视频| 亚洲一区二区国产| 精品视频一区在线视频| 日韩经典中文字幕在线观看| 在线观看欧美日韩| 成人免费在线视频网址| 成人观看高清在线观看免费| 久久男人资源视频| 懂色av影视一区二区三区| 亚洲成年人在线| 欧美第一黄色网| 亚洲一区二区三区777| 欧美成人精品一区| 久久伊人免费视频| 日本国产一区二区三区| 法国裸体一区二区| 欧美极品欧美精品欧美视频| 日韩极品精品视频免费观看| 亚洲精品国产精品久久清纯直播| 亚洲国产精品视频在线观看| 久久影院免费观看| 成人在线视频福利| 亚洲视频视频在线| 在线播放日韩欧美| 欧美日韩亚洲激情| 久久久噜噜噜久久| 国产精品视频26uuu| 亚洲人成伊人成综合网久久久| 久久久久国产视频| 国产成人av网址| 91精品视频大全| 91香蕉电影院| 日韩免费观看高清| 91色视频在线导航| 美女福利精品视频| 欧美日韩亚洲激情| 欧美精品第一页在线播放| 欧美午夜激情小视频| 国产精品久久久久久久久久99| 国产精品美女视频网站| 久久亚洲综合国产精品99麻豆精品福利| www.欧美视频| 欧美精品在线看| 欧美激情在线一区| 国产成人精品久久久| 国产美女直播视频一区| 精品日韩中文字幕|