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

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

?? 蟻群算法程序.txt

?? 基本蟻群算法程序程序在vc++6.0下面同過
?? TXT
字號:
//基本蟻群算法程序

//程序在vc++6.0下面同過,對原來的做了一點修改。
//你可以使用本代碼,如果感到對你有用的話,請通知作者,作者會很高興。
//通訊地址:[email]fashionxu@163.com[/email]
//by FashionXu
#include 
#include 
#include 
#include 
using namespace std;


const int iAntCount=34;//ant numbers
const int iCityCount=51;
const int iItCount=2000;
const double Q=100;
const double alpha=1;
const double beta=5;
const double rou=0.5;

int besttour[iCityCount];

double  rnd(int low,double uper)
{
double p=(rand()/(double)RAND_MAX)*((uper)-(low))+(low);

return (p);
};
int rnd(int uper)
{
return (rand()%uper);
};

class GInfo
{
public: 
double m_dDeltTrial[iCityCount][iCityCount];//信息素增量
double m_dTrial[iCityCount][iCityCount];//信息素痕跡
double distance[iCityCount][iCityCount];//距離
};


GInfo Map;
class ant
{
private:
int ChooseNextCity();
double prob[iCityCount];//轉移概率
int m_iCityCount;
int AllowedCity[iCityCount];
public:
void addcity(int city);
int tabu[iCityCount];//行走路徑
void Clear();
void UpdateResult();
double m_dLength;
double m_dShortest;
void move();
ant();
void move2last();
};
void ant::move2last()
{
int i;
for(i=0;i  if (AllowedCity[i]==1)
  {
   addcity(i);
   break;
  }
}
void ant::Clear()
{
m_dLength=0;
int i;
for(i=0;i {
  prob[i]=0;
  AllowedCity[i]=1;
}
i=tabu[iCityCount-1];
m_iCityCount=0;
addcity(i);
}
ant::ant()
{
m_dLength=m_dShortest=0;
m_iCityCount=0;
int i;
for(i=0;i {
  AllowedCity[i]=1;
  prob[i]=0;
}
}
void ant::addcity(int city)
{
//add city to tabu;
tabu[m_iCityCount]=city;
m_iCityCount++;
AllowedCity[city]=0;
}
int ant::ChooseNextCity()
{
//Update the probability of path selection
//select a path from tabu[m_iCityCount-1] to next


int i;
int j=10000;
double temp=0;
int curCity=tabu[m_iCityCount-1];
for (i=0;i 
{
  if((AllowedCity[i]==1)) 
  {
   temp+=pow((1.0/Map.distance[curCity][i]),beta)*pow((Map.m_dTrial[curCity][i]),alpha);
                          //距離                           //殘留信息量
  }
}
double sel=0;
for (i=0;i 
{  
  if((AllowedCity[i]==1))
  {
   prob[i]=pow((1.0/Map.distance[curCity][i]),beta)*pow((Map.m_dTrial[curCity][i]),alpha)/temp;
   sel+=prob[i];
  }
  else 
   prob[i]=0;
}
double mRate=rnd(0,sel);
double mSelect=0;

for ( i=0;i 
{  
  if((AllowedCity[i]==1))
   mSelect+=prob[i] ;
  if (mSelect>=mRate) 
  {j=i;break;}
}

if (j==10000)
{
  temp=-1;
  for (i=0;i  
{ 
   if((AllowedCity[i]==1))
    if (temp    
   {
     temp=pow((1.0/Map.distance[curCity][i]),beta)*pow((Map.m_dTrial[curCity][i]),alpha);
     j=i;
    }
  }
}

return j;

}
void ant::UpdateResult()
{
// Update the length of tour
int i;
for(i=0;i  m_dLength+=Map.distance[tabu[i]][tabu[i+1]];
m_dLength+=Map.distance[tabu[iCityCount-1]][tabu[0]];
}
void ant::move()
{
//the ant move to next town and add town ID to tabu.
int j;
j=ChooseNextCity();
addcity(j);
}
class project
{
public:

void UpdateTrial();
double m_dLength;
void initmap();
ant ants[iAntCount];
void GetAnt();
void StartSearch();
project();
};
void project::UpdateTrial()
{
//calculate the changes of trial information
int i;
int j;

for(i=0;i {
  for (j=0;j  {
   Map.m_dDeltTrial[ants[i].tabu[j]][ants[i].tabu[j+1]]+=Q/ants[i].m_dLength ;
   Map.m_dDeltTrial[ants[i].tabu[j+1]][ants[i].tabu[j]]+=Q/ants[i].m_dLength;
  }
  Map.m_dDeltTrial[ants[i].tabu[iCityCount-1]][ants[i].tabu[0]]+=Q/ants[i].m_dLength;
  Map.m_dDeltTrial[ants[i].tabu[0]][ants[i].tabu[iCityCount-1]]+=Q/ants[i].m_dLength;
}
for (i=0;i {
  for (j=0;j  {
   Map.m_dTrial[i][j]=(rou*Map.m_dTrial[i][j]+Map.m_dDeltTrial[i][j] );
   Map.m_dDeltTrial[i][j]=0;
  }

}


}
void project::initmap()
{
int i;
int j;
for(i=0;i  for (j=0;j  {

   Map.m_dTrial[i][j]=1;
   Map.m_dDeltTrial[i][j]=0;
  }
}
project::project()
{
//initial map,read map infomation from file . et.
initmap();
m_dLength=10e9;


ifstream in("eil51.tsp");

struct city
{
  int num;
  int x;
  int  y;
}cc[iCityCount];

for (int i=0;i 
{
  in>>cc[i].num>>cc[i].x>>cc[i].y;
  besttour[i]=0;
}
int j;
for(i=0;i  for (j=0;j  
{
   {
    Map.distance[i][j]=sqrt(pow((cc[i].x-cc[j].x),2)+pow((cc[i].y-cc[j].y),2));
   }
}


}
void project::GetAnt()
{
//randomly put ant into map
int i=0;
int city;
srand( (unsigned)time( NULL ) +rand());
for (i=0;i {
  city=rnd(iCityCount);
  ants[i].addcity(city);
}

}
void project::StartSearch()
{
//begin to find best solution
int max=0;//every ant tours times
int i;
int j;
double temp;
int temptour[iCityCount];
while (max 
{  
  for(j=0;j

  { 
   for (i=0;i    ants[j].move();
  }

  for(j=0;j  
{
   ants[j].move2last();
   ants[j].UpdateResult ();
  }

  //find out the best solution of the step and put it into temp
  int t;
  temp=ants[0].m_dLength;
  for (t=0;t   
  temptour[t]=ants[0].tabu[t];
  for(j=0;j  
{
   if (temp>ants[j].m_dLength) 
   {
    temp=ants[j].m_dLength;
    for ( t=0;t     temptour[t]=ants[j].tabu[t];
   }

  }

  if(temp   
  m_dLength=temp;
   for ( t=0;t
  {
   besttour[t]=temptour[t];
  }
  printf("%d : %f\n",max,m_dLength);
  UpdateTrial(); 

  for(j=0;j   ants[j].Clear();

  max++;

}
printf("The shortest toure is : %f\n",m_dLength);

for ( int t=0;t  printf(" %d ",besttour[t]);

}
int main()
{

project TSP;
TSP.GetAnt();
TSP.StartSearch();
return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久综合中文综合网| 欧美日韩在线三区| 无码av中文一区二区三区桃花岛| 中文字幕中文乱码欧美一区二区| 久久久久久9999| 久久综合九色综合欧美亚洲| 欧美videos中文字幕| 日韩免费成人网| 日韩精品中文字幕一区二区三区| 91麻豆精品国产91久久久久久| 日韩专区欧美专区| 亚洲欧美日韩人成在线播放| 国产精品美女久久久久久久久| 久久女同性恋中文字幕| 中文文精品字幕一区二区| 国产日韩欧美激情| 亚洲免费观看高清在线观看| 亚洲影院理伦片| 日本免费新一区视频| 国产一区二区在线视频| 北条麻妃一区二区三区| 在线这里只有精品| 日韩免费高清视频| 国产精品高潮呻吟久久| 午夜精品一区二区三区免费视频| 午夜影院久久久| 国产精品中文字幕日韩精品| 国产成人在线电影| 欧美三区在线视频| 精品国产电影一区二区| 国产精品国产精品国产专区不片| 夜夜嗨av一区二区三区 | 国产精品99久久久| 91啪九色porn原创视频在线观看| 欧美精品色综合| 国产亚洲精品资源在线26u| 亚洲视频一区在线观看| 男女视频一区二区| 色婷婷激情综合| 一区二区久久久久| 日本视频中文字幕一区二区三区| 成人性生交大片| 欧美日韩精品一区二区三区| 狠狠色丁香久久婷婷综| 国产精品66部| 制服丝袜亚洲精品中文字幕| 国产精品美女久久久久av爽李琼| 亚洲妇女屁股眼交7| 国产成人亚洲综合a∨婷婷图片| 欧美亚洲禁片免费| 国产精品日韩成人| 美女视频黄免费的久久| 欧美色区777第一页| 中文字幕乱码久久午夜不卡 | 亚洲精品国产一区二区三区四区在线| 视频一区二区三区在线| 99久久精品费精品国产一区二区| 欧美成人综合网站| 日韩成人精品视频| 91久久久免费一区二区| 欧美亚洲自拍偷拍| 久久综合久久鬼色中文字| 日韩精品免费专区| 欧美在线视频不卡| 亚洲欧美一区二区不卡| 成人免费的视频| 国产午夜精品一区二区三区嫩草| 美女国产一区二区| 欧美一卡2卡3卡4卡| 亚洲成人av在线电影| 91国产福利在线| 一区二区三区四区不卡在线| 99综合电影在线视频| 国产目拍亚洲精品99久久精品| 久久国产精品区| 日韩亚洲欧美在线| 久久国产福利国产秒拍| 欧美精品一区二区三区高清aⅴ| 日韩在线卡一卡二| 日韩女优毛片在线| 久久综合久久综合久久综合| 日韩专区中文字幕一区二区| 欧美三级在线看| 男女性色大片免费观看一区二区| 欧美日韩国产一级片| 奇米在线7777在线精品| 精品人在线二区三区| 国产一区二区在线视频| 日本一区二区免费在线| 91麻豆国产精品久久| 亚洲成人精品一区| 日韩欧美亚洲国产另类| 成人影视亚洲图片在线| 亚洲狠狠丁香婷婷综合久久久| 欧美撒尿777hd撒尿| 麻豆国产一区二区| 国产精品素人一区二区| 色综合视频一区二区三区高清| 亚洲一二三专区| 日韩欧美在线网站| 国产69精品久久久久777| 亚洲人成亚洲人成在线观看图片| 欧美在线免费观看亚洲| 久久成人精品无人区| 日本一区二区不卡视频| 欧美色爱综合网| 丁香啪啪综合成人亚洲小说| 亚洲大片免费看| 国产色婷婷亚洲99精品小说| 欧美专区在线观看一区| 国产麻豆欧美日韩一区| 一区二区三区自拍| 久久夜色精品国产欧美乱极品| 99国产精品99久久久久久| 亚洲国产sm捆绑调教视频| 久久婷婷一区二区三区| 欧美性大战久久久久久久 | 欧美艳星brazzers| 韩国三级电影一区二区| 亚洲第一主播视频| 最新欧美精品一区二区三区| 91麻豆精品国产91久久久使用方法| 福利电影一区二区三区| 伦理电影国产精品| 亚洲不卡av一区二区三区| 久久九九全国免费| 日韩精品一区二| 欧美日韩国产一二三| www.亚洲人| 国产成人精品免费网站| 日韩高清国产一区在线| 一区二区三区四区精品在线视频 | 亚洲午夜免费视频| 一区在线播放视频| 久久久久国产精品人| 日韩亚洲国产中文字幕欧美| 欧美三级中文字幕| 在线视频国内自拍亚洲视频| 91亚洲国产成人精品一区二区三| 韩国中文字幕2020精品| 秋霞影院一区二区| 日韩电影在线免费观看| 亚洲亚洲精品在线观看| 一区二区激情小说| 亚洲自拍偷拍av| 一区二区三区在线不卡| 亚洲美女电影在线| 亚洲欧美区自拍先锋| 成人免费av网站| 97se亚洲国产综合自在线| 国产精品一区三区| 国产自产v一区二区三区c| 美女一区二区视频| 日本成人在线一区| 久久精品国产**网站演员| 捆绑调教一区二区三区| 美女脱光内衣内裤视频久久网站 | 久久99久久精品| 热久久国产精品| 久久精品999| 国产风韵犹存在线视精品| 国产91精品一区二区麻豆亚洲| 国产成人免费视频精品含羞草妖精| 久久91精品国产91久久小草| 国产一区二区主播在线| 成人av小说网| 91福利在线观看| 欧美精品电影在线播放| 精品美女在线播放| 国产精品久久久久久久久果冻传媒| 日韩码欧中文字| 亚洲伊人伊色伊影伊综合网| 日韩va欧美va亚洲va久久| 国产乱子轮精品视频| k8久久久一区二区三区| 欧美午夜精品久久久| 日韩久久久精品| 中文一区二区完整视频在线观看| 国产精品久久二区二区| 亚洲成人黄色小说| 国产盗摄一区二区| 精品视频1区2区| 欧美精品一区二区在线观看| 国产精品九色蝌蚪自拍| 视频一区欧美日韩| 丰满岳乱妇一区二区三区| 91精品福利视频| 精品久久久久久久久久久久久久久| 日本一区免费视频| 日产国产高清一区二区三区| 成人美女视频在线观看| 51精品视频一区二区三区| 亚洲国产高清aⅴ视频| 水蜜桃久久夜色精品一区的特点| 国产精品综合在线视频| 欧美熟乱第一页| 国产蜜臀av在线一区二区三区| 污片在线观看一区二区| 91免费看视频| 国产欧美一区二区精品仙草咪|