亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 旅行推銷員問題之c語言算.txt

?? c語言的一些常見的算法以及思考和改進的文章,寫的很不錯,花費了很大的精力從網絡了搜羅的,希望大家喜歡.
?? TXT
字號:
旅行推銷員問題之C語言算法[原創] 
旅行推銷員問題:一位旅行推銷員想要訪問n個城市中每個城市恰好一次,并且返回到出發點。應如何走才能使總距離最短?其實就是求帶權完全無向圖中訪問每個頂點恰好一次并且返回出發點的總權數最小的回路,即總權數最小的哈密頓回路。

思路:把n個城市做全排列,并求出每種排列對應的總距離,然后選擇最短的一個。

推論:把上面求出的最短哈密頓回路看作一個圓,求出最短哈密頓回路以后,從回路上任一點開始出發而訪問每個頂點一次,總距離是相等的。因為總距離與圓周相等。

代碼(效率有待于提高,因為多判斷了一半的回路,即一條路反方向和正方向各判斷了一次):

/*
   程序功能:求解旅行推銷員問題
   作者:BugEyes
   主頁:http://bugeyes.blog.edu.cn
*/

int flag=0;/*用來標記回路是否檢查完畢*/

int search(int distance[5][5],int start,int result[5]);
void next(int array[],int n);
void sort(int array[],int start,int end);
int dis_compute(int distance[5][5],int result[5]);
void chuli(int t_result[],int result[],int start,int n);


void main()
{
   int i,j,start;/*start表示出發點城市編號*/
   int distance[5][5]={{0,50,30,7,60},/*模擬城市之間的距離*/
                                {50,0,40,76,89},
                                {30,40,0,10,70},
                                {70,76,100,0,80},
                                {90,89,70,80,0}};
   int result[5]={0};/*存放最短哈密頓回路*/
   int dis_result=0;/*存放最短總距離*/
   printf("\nThe distance of cities are as follows:\n");
   for(i=0;i<5;i++)
   {
      for(j=0;j<=i;j++)
             printf("%4d",distance[i][j]);
      printf("\n\n");
   }
   printf("Please input the city number to start.Input -1 to exit.\n");
   scanf("%d",&start);
   while(start<-1||start>4)
   {
      printf("Sorry,you are wrong.\nPlease input the city number to start.Input -1 to exit.\n");
      scanf("%d",&start);
   }
   if(start==-1)/*-1表示結束程序*/
   {
      printf("\nBye.Good luck!\n");
      return;
   }
   printf("\nOK.Let's go!!!\n");
   dis_result=search(distance,start,result);/*計算最短哈密頓回路,并求總距離*/
   printf("\nThe best route is:\n");
   for(i=0;i<5;i++)
      printf("%4d->",result[i]);
   printf("%4d\n",result[0]);
   printf("And the whole distance is:%d\n",dis_result);
}

int search(int distance[5][5],int start,int result[5])
{
   int i,j;
   int t_distance,r_distance;
   int t_result[5]={0,1,2,3,4};
   int r_result[5];
   printf("\nI am in search function...........");
   t_distance=r_distance=dis_compute(distance,t_result);
   while(flag==0)
   {
      next(t_result,5);
      chuli(t_result,r_result,start,5);
      if((t_distance=dis_compute(distance,r_result))<r_distance)
      {/*若當前回路總距離在檢查過的回路中最小*/
             r_distance=t_distance;
             chuli(t_result,result,start,5);
      }
   }
   printf("\nI am leaving search function...............");
   return r_distance;
}

void next(int array[],int n)
{ /*計算下一個可能的回路,其實就是求排列*/
   int i,j,temp;
   printf("\nI am in next function..........................");
   flag=0;
   for(i=n-2;i>=0;i--)
      if(array[i]<array[i+1])
          break;
   for(j=n-1;j>i;j--)
      if(array[j]>array[i])
           break;
   if(j==i)
   {/*已是最后一條回路*/
      flag=1;
      return;
   }
   temp=array[i];
   array[i]=array[j];
   array[j]=temp;
   sort(array,i+1,n);
   printf("\nI am leaving next function..........................");
}

void sort(int array[],int start,int end)
{
   int i,j;
   printf("\nI am in sort function...............................");
   for(i=start;i<end-start;i++)
      for(j=start;j<end-1;j++)
  if(array[j]>array[j+1])
  {
     int t=array[j];
     array[j]=array[j+1];
     array[j+1]=t;
  }
   printf("\nI am leaving sort function...........................");
}

int dis_compute(int distance[5][5],int result[5])
{/*計算當前回路對應的總距離*/
    int r_distance=0;
    int i;
    printf("\nI am in dis_compute function.........................");
    for(i=0;i<5;i++)
        r_distance+=distance[result[i]][result[(i+1)%5]];
    printf("\nI am leaving dis_compute function...................");
    return r_distance;
}

void chuli(int t_result[],int result[],int start,int n)
{/*對選擇的回路重新排列,按出發點---->路徑---->出發點的順序排列*/
   int i,pos;
   printf("\nI am in chuli function..............................");
   for(i=0;i<n;i++)
      if(t_result[i]==start)
             break;
   pos=i;
   for(i=0;i<n;i++)
      result[i]=t_result[(pos+i)%n];
   printf("\nI am leaving chuli function.......................");
}

 

時間倉促,可能有考慮不周之處,請大家不吝賜教!
 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
96av麻豆蜜桃一区二区| 粗大黑人巨茎大战欧美成人| 91在线看国产| 国产在线精品国自产拍免费| 综合久久久久综合| 日韩一区二区精品在线观看| 成人av影院在线| 日本大胆欧美人术艺术动态| 国产日韩精品一区二区浪潮av| 色8久久人人97超碰香蕉987| 久久成人免费日本黄色| 亚洲免费av观看| 久久久99精品免费观看不卡| 欧美怡红院视频| 成人免费视频播放| 91美女视频网站| 国产99久久久国产精品| 日本伊人午夜精品| 久久电影网站中文字幕 | 极品销魂美女一区二区三区| 中文字幕色av一区二区三区| 日韩一区二区免费高清| 精品免费视频一区二区| 欧美美女网站色| 在线视频欧美区| 91亚洲资源网| 91麻豆精品国产91久久久久 | 欧美日韩国产综合视频在线观看| 高清在线不卡av| 日本道色综合久久| 欧美一级夜夜爽| 51精品国自产在线| 久久精品在线观看| 亚洲柠檬福利资源导航| 日韩av一级片| 91网上在线视频| 91精品欧美久久久久久动漫| 久久久99精品免费观看不卡| 一区二区欧美在线观看| 亚洲另类春色校园小说| 国产精品国产自产拍在线| 欧美激情一区二区在线| 久久久亚洲高清| 久久精品视频免费观看| 亚洲一区二区三区小说| 亚洲自拍偷拍综合| 国产专区欧美精品| 成人激情av网| 日韩一级大片在线| 亚洲欧美成aⅴ人在线观看| 极品少妇xxxx偷拍精品少妇| 色八戒一区二区三区| 国产网红主播福利一区二区| 午夜精品一区在线观看| 毛片一区二区三区| 国产福利一区在线| 91免费看片在线观看| 久久精品一区蜜桃臀影院| 日韩福利视频导航| 91黄色免费网站| 亚洲天堂免费在线观看视频| 国产一区二区剧情av在线| 6080国产精品一区二区| 亚洲一区国产视频| 一本久道久久综合中文字幕| 欧美日韩一区精品| 久久综合九色综合欧美98 | 福利91精品一区二区三区| 欧美一区二区三区思思人| 亚洲国产精品久久久久婷婷884| 污片在线观看一区二区| 91色在线porny| 亚洲天堂成人在线观看| 91在线丨porny丨国产| 国产欧美日韩一区二区三区在线观看| 久久91精品久久久久久秒播| 欧美一区二区私人影院日本| 日韩av一区二区三区| 7777精品伊人久久久大香线蕉最新版| 亚洲福利视频三区| 日本精品视频一区二区| 一区二区成人在线| 欧美三级三级三级爽爽爽| 亚洲成人手机在线| jizzjizzjizz欧美| 精品久久久久久久久久久久久久久久久| 亚洲va欧美va国产va天堂影院| 欧美日韩国产美| 日本午夜一区二区| 久久亚洲综合av| 丁香婷婷综合激情五月色| 亚洲欧美在线另类| 日本高清视频一区二区| 三级精品在线观看| 91精品福利视频| 蜜臀久久99精品久久久画质超高清 | 成人免费小视频| 色综合久久久久久久久久久| 亚洲一区av在线| 日韩欧美色综合| 日韩不卡免费视频| 久久精品网站免费观看| 色综合久久久久综合体| 蜜臀av一级做a爰片久久| 久久―日本道色综合久久| 99精品视频在线观看| 婷婷成人激情在线网| 精品国产乱码久久久久久闺蜜 | 久久综合九色综合欧美就去吻 | 国内精品伊人久久久久影院对白| 欧美国产欧美综合| 欧美日韩高清影院| 成人一区二区视频| 一区二区三区四区精品在线视频| 日韩欧美亚洲另类制服综合在线| 丁香一区二区三区| 美女高潮久久久| 国产精品久久看| 欧美成人a∨高清免费观看| 不卡一区二区在线| 久久99精品久久久久久动态图| 中文字幕制服丝袜成人av | 国产美女视频91| 亚洲一区在线电影| 中文字幕不卡在线播放| 91精品国产美女浴室洗澡无遮挡| 不卡一区二区中文字幕| 久久99精品一区二区三区| 一二三区精品福利视频| 国产人成一区二区三区影院| 91精品国产综合久久久蜜臀图片 | 日韩欧美激情在线| 一本色道a无线码一区v| 风流少妇一区二区| 久久激情五月婷婷| 日韩激情一二三区| 亚洲自拍与偷拍| 亚洲黄色免费网站| 国产精品久久久久久久久搜平片| 欧美精品一区二区三区四区| 欧美日韩精品系列| 欧美最猛黑人xxxxx猛交| av中文字幕一区| 高清国产一区二区三区| 国产在线视频一区二区| 日本不卡在线视频| 日韩精品电影在线观看| 三级欧美韩日大片在线看| 一区二区理论电影在线观看| 亚洲欧美激情视频在线观看一区二区三区| 久久色中文字幕| 久久久综合九色合综国产精品| 日韩欧美国产三级电影视频| 日韩一区二区影院| 日韩欧美第一区| 久久一区二区三区国产精品| xfplay精品久久| 国产亚洲欧美日韩在线一区| 久久久国产精华| 国产精品欧美久久久久无广告| 欧美亚洲综合在线| 欧美性受xxxx| 欧美肥胖老妇做爰| 日韩精品专区在线| 久久久久久夜精品精品免费| 久久久精品免费观看| 国产欧美久久久精品影院| 欧美国产1区2区| 亚洲精品乱码久久久久久日本蜜臀 | 777午夜精品免费视频| 日韩一区二区免费视频| 久久综合一区二区| 国产精品国产三级国产a| 一区二区国产视频| 蜜桃av噜噜一区| 国产91精品精华液一区二区三区 | 欧美卡1卡2卡| 精品国产伦一区二区三区观看方式| 久久久精品国产免大香伊| 国产精品白丝在线| 天天色 色综合| 国产精品18久久久久久久久 | 日日夜夜免费精品视频| 美美哒免费高清在线观看视频一区二区 | jizzjizzjizz欧美| 欧美视频在线一区| 精品国产自在久精品国产| 久久久天堂av| 亚洲国产精品久久久久秋霞影院| 蓝色福利精品导航| 一本在线高清不卡dvd| 日韩视频免费直播| 亚洲美女少妇撒尿| 狠狠狠色丁香婷婷综合激情 | 美女视频黄免费的久久| hitomi一区二区三区精品| 日韩女优电影在线观看| 亚洲精品中文字幕在线观看| 国产在线不卡视频| 欧美精品 国产精品|