久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2370|回復(fù): 0
收起左側(cè)

弗洛伊德算法和迪杰斯特拉算法求最短路徑 VC++6.0源程序

[復(fù)制鏈接]
ID:767505 發(fā)表于 2020-6-3 20:40 | 顯示全部樓層 |閱讀模式
實驗一 弗洛伊德算法
實驗?zāi)康模焊ヂ逡恋滤惴ㄇ笞疃搪窂?br /> 實驗內(nèi)容:
  1. #include <stdio.h>
  2. void main()
  3. {
  4.     int e[9][9],k,i,j,n,m,t1,t2,t3;
  5.     int inf=99999999; //用inf(infinity的縮寫)存儲一個我們認(rèn)為的正無窮值
  6.     scanf("%d %d",&n,&m);//讀入n和m,n表示頂點個數(shù),m表示邊的條數(shù)
  7.     //初始化
  8.     for(i=1;i<=n;i++)
  9.         for(j=1;j<=n;j++)
  10.             if(i==j) e[i][j]=0;  
  11.               else e[i][j]=inf;
  12.     //讀入邊
  13.     for(i=1;i<=m;i++)
  14.     {
  15.         scanf("%d %d %d",&t1,&t2,&t3);
  16.         e[t1][t2]=t3;
  17.     }
  18.     for(k=1;k<=n;k++)
  19.         for(i=1;i<=n;i++)
  20.             for(j=1;j<=n;j++)
  21.                 if(e[i][j]>e[i][k]+e[k][j] )
  22.                     e[i][j]=e[i][k]+e[k][j];
  23.     for(i=1;i<=n;i++)
  24.     {
  25.      for(j=1;j<=n;j++)
  26.         {
  27.             printf("%10d",e[i][j]);
  28.         }
  29.         printf("\n");
  30.     }
  31.    
  32. }
復(fù)制代碼

/* 測試數(shù)據(jù) n=4 m=5
邊的數(shù)據(jù)
1 2 5
1 3 6
2 3 1
2 4 4
3 4 4
輸出結(jié)果
0          5          6           9
99999999   0          1           4
99999999   99999999   0           4
99999999   99999999   99999999    0

*/

實驗一 迪杰斯特拉算法
實驗?zāi)康模旱辖芩固乩惴ㄇ笞疃搪窂?br /> 實驗內(nèi)容:
  1. #include<stdio.h>
  2. #define SIZE 110  
  3. #define INF 1000000;  
  4. int map[SIZE][SIZE];    //鄰接矩陣存儲
  5. int len[SIZE];         //d[i]表示源點到i這個點的距離
  6. int visit[SIZE];      //節(jié)點是否被訪問
  7. int n,m;  
  8. int dijkstra(int from, int to)//從源點到目標(biāo)點
  9. {                     
  10.     int i;  
  11.     for(i = 1 ; i <= n ; i ++)//初始化
  12.     {     
  13.         visit[i] = 0;    //一開始每個點都沒被訪問
  14.         len[i] = map[from][i];    //先假設(shè)源點到其他點的距離

  15.     }  
  16.     int j;  
  17.     for(i = 1 ; i < n ; ++i)//對除源點的每一個點進(jìn)行最短計算
  18.     {
  19.     int min = INF;  //記錄最小len[i]
  20.     int pos;  //記錄小len[i] 的點
  21.       for(j = 1 ; j <= n ; ++j)
  22.       {     

  23.             if(!visit[j] && min > len[j])
  24.             {
  25.                 pos = j;  
  26.                 min = len[j];  
  27.             }  
  28.       }  
  29.         visit[pos] = 1;  
  30.          for(j = 1 ; j <= n ; ++j)
  31.          {
  32.             if(!visit[j] && (len[j] > (len[pos] +map[pos][j])))
  33.             { //如果j節(jié)點沒有被訪問過&&j節(jié)點到源節(jié)點的最短路徑>pos節(jié)點到源節(jié)點的最短路徑+pos節(jié)點到j(luò)節(jié)點的路徑  

  34.                 len[j] = len[pos] + map[pos][j];    //更新j節(jié)點到源節(jié)點的最短路徑   
  35.             }  
  36.          }  
  37.     }  
  38.     return len[to];

  39. }
  40.     int main ()
  41. {  
  42.     int i,j;  
  43.   //  scanf("%d%d",&n,&m);    //輸入數(shù)據(jù)
  44.     n = 6;    //測試數(shù)據(jù)
  45.     m = 9;
  46.     for(i = 1 ; i <= n ; ++i)
  47.     {    //設(shè)一開始每個點都不可達(dá)
  48.         for(j = 1 ; j <= n ; ++j)
  49.         {  
  50.             map[i][j] = INF;  
  51.         }  
  52.     }     
  53. /*    int a,b,c;    //輸入數(shù)據(jù)

  54.     for(i = 1 ; i <= m ; ++i)
  55.     {  
  56.     scanf("%d%d%d",&a,&b,&c);  
  57.     map[a][b] = map[b][a] = c;  
  58.     }  */
  59.     map[1][2] = 5;    //測試數(shù)據(jù)
  60.     map[1][3] = 8;
  61.     map[1][6] = 3;
  62.     map[1][4] = 7;
  63.     map[2][3] = 4;
  64.     map[3][6] = 9;
  65.     map[4][6] = 6;
  66.     map[5][6] = 1;
  67.     map[4][5] = 5;
  68.     map[3][4] = 5;
  69.     int temp = INF;
  70.     for(i = 1 ; i <= n ; ++i)
  71.     {
  72.       for(j = 1 ; j <= n ; ++j)
  73.       {
  74.     if(map[i][j] == temp)
  75.     map[i][j] = map[j][i];
  76.       }
  77.     }
  78.     int ans = dijkstra(1,5);  
  79.     printf("%d",ans);  
  80.     return 0;  
  81. }
復(fù)制代碼

/* 邊的數(shù)據(jù)
1 2 5
1 3 8
1 6 3
1 4 7
2 3 4
3 6 9
5 6 1
4 5 5
3 4 5
*/

弗洛伊德算法和迪杰斯特拉算法求最短路徑.doc

27.5 KB, 下載次數(shù): 6, 下載積分: 黑幣 -5

評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 日韩一区二区在线看 | 中文字幕1区2区 | 精品一区二区三区四区外站 | 操射视频| 国产激情福利 | www.中文字幕.com | 亚洲精品在线免费观看视频 | 国产精品一区二区在线免费观看 | 国产成人综合亚洲欧美94在线 | 日韩在线一区二区 | 日韩在线大片 | 影视一区| 欧美一级在线观看 | 日日夜夜狠狠操 | 亚洲福利视频一区二区 | 国产精品成人国产乱一区 | 在线中文字幕亚洲 | 成人亚洲视频 | 草草网 | 亚洲国产一区二区三区四区 | 天天摸天天看 | 免费中文字幕 | 国产精品成人免费 | 北条麻妃99精品青青久久 | 一级黄色片免费 | 一区久久 | 久久国产精品免费一区二区三区 | 成人在线视频免费观看 | 国产精品一级 | 武道仙尊动漫在线观看 | 91大神在线资源观看无广告 | 色婷婷av一区二区三区软件 | 亚洲一区二区精品 | 成年人在线观看 | 色天堂视频 | 亚洲成年在线 | 国产亚洲一区二区三区在线 | 波多野结衣一区二区 | 99热在线免费 | 成人网av | 色综合色综合网色综合 |