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

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

?? tspts.cpp

?? 用禁忌搜索解決TSP問題
?? CPP
字號:
//author: yinhui
//Date  : 2007.06.15

//TSPSA.cpp

#include "StdAfx.h"
#include "tspts.h"
#include <math.h>
#include <algorithm>

#define MAX_SAME 40

void TabuSearch::Init()
{
	srand((unsigned)time(NULL));
	ComputeTotalDistace();
	CreateInitSolution(m_vecRouter);
}

void TabuSearch::ObtainParams(int nTabuLength, int nCandSize, int nIterCount, 
							 int nSameCount, VecCity vCitys, int nCityNum)
{
	m_nTabuLength = nTabuLength;
	m_nCandSize = nCandSize;
	m_nSameCount = nSameCount;
	m_nIterCount = nIterCount;
	m_vecCitys = vCitys;
	m_nCityNum = nCityNum;
}

void TabuSearch::CreateInitSolution(vecCityRouter& initRouter)
{
	for (int i=1; i<=m_nCityNum; i++)
	{
		initRouter.push_back(i);
		//m_vecRouter.push_back(i);
	}
	std::random_shuffle(initRouter.begin(), initRouter.end());
}

vecCityRouter TabuSearch::NextSolution()
{
	int fSwap, eSwap;
	vecCityRouter tempRouter;
	tempRouter = m_vecRouter;

	while (1)
	{
		fSwap = (rand()%m_nCityNum)-1;
		if (fSwap>=0)
			break;
	}

	while (1)
	{
		eSwap = (rand()%m_nCityNum)-1;
		if ((eSwap!=fSwap) && (eSwap>=0))
		{
			int temp = tempRouter[fSwap];
			int xx = tempRouter[eSwap];
			tempRouter[fSwap] = tempRouter[eSwap];
			tempRouter[eSwap] = temp;
			break;
		}
	}
	return tempRouter;
}

void TabuSearch::ComputeTotalDistace()
{
	std::vector<City>::iterator fCityIter;
	std::vector<City>::iterator eCityIter;

	Distance tempDist;

	for (fCityIter=m_vecCitys.begin(); fCityIter!=m_vecCitys.end(); fCityIter++)
	{
		for (eCityIter=m_vecCitys.begin(); eCityIter!=m_vecCitys.end(); eCityIter++)
		{
			ComputeDistance(*fCityIter, *eCityIter, tempDist);
			m_vecDistance.push_back(tempDist);
		}
	}
}

double TabuSearch::ComputeDistance(City& fCity, City& eCity, Distance& cityDist)
{
	double tempDist;

	float fCityX = fCity.m_corCity.m_fX;
	float fCityY = fCity.m_corCity.m_fY;
	float eCityX = eCity.m_corCity.m_fX;
	float eCityY = eCity.m_corCity.m_fY;

	tempDist = sqrt((fCityX-eCityX)*(fCityX-eCityX) +
		            (fCityY-eCityY)*(fCityY-eCityY));

	cityDist.m_nFromCity = fCity.m_nIndex;
	cityDist.m_nEndCity = eCity.m_nIndex;
	cityDist.m_fDist = (float)tempDist;

	return tempDist;
}

double TabuSearch::FindDistance(int fIndex, int eIndex)
{
	VecDistance::iterator tempIter;

	for (tempIter=m_vecDistance.begin(); tempIter!=m_vecDistance.end(); tempIter++)
	{
		if ((tempIter->m_nFromCity==fIndex) && (tempIter->m_nEndCity==eIndex))
		{
			return tempIter->m_fDist;
		}
	}
	return 0.0;
}

double TabuSearch::ComputeRouterDistance(vecCityRouter& curCityRou)
{
	vecCityRouter::iterator tempRouterIter;
	double allDist=0.0;

	for (tempRouterIter=curCityRou.begin(); tempRouterIter!=(curCityRou.end()-1); tempRouterIter++)
	{
		allDist += FindDistance(*tempRouterIter, *(tempRouterIter+1));
	}

	allDist += FindDistance(*(curCityRou.end()), *(curCityRou.begin()));
	return allDist;
}

float TabuSearch::GetNowDistance()
{
	float dist;
	dist = (float)ComputeRouterDistance(m_vecRouter);
	return dist;
}

float TabuSearch::DoOneSearch(float t)
{
	double currDist = ComputeRouterDistance(m_vecRouter);
	vecCityRouter nextRouter = NextSolution();
	double nextDist = ComputeRouterDistance(nextRouter);

	double random = (double)rand()/(double)RAND_MAX;
	if ((nextDist-currDist) < 1.0e-6)
	{
		m_vecRouter = nextRouter;
	}
	/*else if (exp((currDist-nextDist)/t) > random)
	{
		m_vecRouter = nextRouter;
	}*/
		
	return (float)nextDist;
}

void TabuSearch::TSPTabuSearch(CListBox *pLB)
{
	pLB->ResetContent();
	CString strDisplay, strValue;
	strDisplay = "城市個數:";
	strValue.Format("%d\n", m_nCityNum);
	strDisplay += strValue;
	pLB->InsertString(0,strDisplay);

	int nIterCount = 0;    //對迭代次數計數
	int nSameCount = 0;    //對最優解重復次數計數
	int nCandCount = 0;    //候選解總個數
	int i = 0;

	listTabuList tl;
	TabuListItem tlItem;

	double dNowDist = ComputeRouterDistance(m_vecRouter);
	tlItem.length = dNowDist;
	tlItem.count = MAXTABUCOUNT;
	tl.push_back(tlItem);

	vecCityRouter vecNextRouter;

	double dBestDist = dNowDist;
	double tempDist = 0;
	double countDist = dNowDist;    //記錄相同解

	
	strDisplay = "初始距離:";
	strValue.Format("%f\n", dBestDist);
	strDisplay += strValue;
	pLB->InsertString(0, strDisplay);

	while (nIterCount<m_nIterCount && nSameCount<m_nSameCount)
	{
		while (nCandCount<m_nCandSize)
		{
			nCandCount++;
            vecNextRouter = NextSolution();
			dNowDist = ComputeRouterDistance(vecNextRouter);

			listTabuList::iterator iterList;
			for (iterList=tl.begin(); iterList!=tl.end(); iterList++)
			{
				tempDist = iterList->length;
				if ((abs(dNowDist-tempDist)) < 1.0e-8)
				{//如果距離已在禁忌表中
					(iterList->count)--;
					if (iterList->count == 0)
					{//如果已滿足特赦條件
						tl.erase(iterList);
						nCandCount--;
					}
					break;
				}else
				{//如果距離不在禁忌表中
					tlItem.length = dNowDist;
					tlItem.count = MAXTABUCOUNT;

					if (tl.size() < m_nTabuLength)
					{//如果禁忌表未滿
						tl.push_back(tlItem);
					}
					else
					{//如果禁忌表已滿,從表頭刪除一個元素
						tl.pop_front();
						tl.push_back(tlItem);
					}
				}
			}//end for (iterList=tl.begin(); iterList!=tl.end(); iterList++)

			//從候選集中選擇最優解
			if (dNowDist < dBestDist)
			{//當前解更憂
				dBestDist = dNowDist;
				m_vecRouter = vecNextRouter;
			}
			strDisplay = "當前最優解:";
	        strValue.Format("%f\n", dBestDist);
	        strDisplay += strValue;
	        pLB->InsertString(0, strDisplay);

		}//end while (nCandCount<m_nCandSize)
		if (abs(countDist-dBestDist) < 1.0e-8)
		{//相同解又出現
			nSameCount++;
		}
		else
		{
			nSameCount = 0;
			countDist = dBestDist;
		}
		
		nIterCount++;
	}//end while (nIterCount<m_nIterCount && nSameCount<m_nSameCount)
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人在线网站| 欧美刺激午夜性久久久久久久| 欧美日韩国产一二三| 久久久久久久久伊人| 一区二区三区久久| 高清在线观看日韩| 欧美一区二区三区免费大片| 最好看的中文字幕久久| 国产一区不卡精品| 国产精品久久午夜| 国产一区二区三区香蕉| 91.com视频| 视频一区中文字幕| 在线观看91精品国产入口| 国产视频在线观看一区二区三区| 三级在线观看一区二区| 欧美亚洲精品一区| 亚洲欧美日本韩国| av资源站一区| 中文字幕在线视频一区| 国产白丝网站精品污在线入口| 日韩欧美国产成人一区二区| 日本欧美在线观看| 欧美精品久久99| 亚洲电影欧美电影有声小说| 91麻豆123| 国产精品久久久久7777按摩| 国产成人亚洲综合a∨猫咪| 久久久久国产精品免费免费搜索| 麻豆免费精品视频| 欧美r级电影在线观看| 久久精品99国产国产精| 91精品免费观看| 午夜激情久久久| 欧美人牲a欧美精品| 日韩av在线播放中文字幕| 欧美丰满少妇xxxbbb| 五月天中文字幕一区二区| 69堂国产成人免费视频| 麻豆精品精品国产自在97香蕉| 制服丝袜中文字幕亚洲| 蜜臀精品久久久久久蜜臀| 日韩欧美高清一区| 国产在线精品一区在线观看麻豆| 久久嫩草精品久久久精品一| 高清不卡一区二区在线| 中文字幕一区二区三区av| 色综合久久精品| 五月天久久比比资源色| 欧美成人vps| 成人性视频网站| 亚洲成人av电影在线| 欧美电影免费观看高清完整版在线观看 | 成人午夜在线视频| 亚洲欧美一区二区三区极速播放 | 色婷婷久久久综合中文字幕| 亚洲福利一二三区| 日韩欧美不卡在线观看视频| 国产精品亚洲一区二区三区在线| 国产精品丝袜一区| 欧美日精品一区视频| 国产自产视频一区二区三区| 国产精品免费av| 欧美久久久影院| 国产精品一级二级三级| 一区二区三区欧美| 国产精品另类一区| 在线观看国产一区二区| 蜜桃av一区二区在线观看| 国产精品久久毛片| 日韩一级免费观看| 成人av资源在线观看| 日韩高清在线一区| 中文字幕佐山爱一区二区免费| 欧美浪妇xxxx高跟鞋交| 成人在线综合网站| 日韩中文欧美在线| 国产精品久久久久久久久动漫| 91精选在线观看| 99久久久精品| 老司机精品视频一区二区三区| 中文字幕欧美一区| 精品久久久久久久人人人人传媒| 色综合天天在线| 国产精品1024| 久久精品国产在热久久| 一区二区三区在线不卡| 久久精品亚洲精品国产欧美kt∨ | 日本高清不卡视频| 国产成人8x视频一区二区| 午夜av电影一区| 综合婷婷亚洲小说| 中文字幕高清一区| 久久综合精品国产一区二区三区| 欧美影片第一页| av亚洲产国偷v产偷v自拍| 久久99精品久久久久婷婷| 午夜电影一区二区三区| 亚洲最新在线观看| 国产香蕉久久精品综合网| 884aa四虎影成人精品一区| 色噜噜偷拍精品综合在线| 粉嫩av一区二区三区粉嫩| 韩国v欧美v亚洲v日本v| 日本午夜一本久久久综合| 一级特黄大欧美久久久| 1000精品久久久久久久久| 久久久精品综合| 国产亚洲精品aa午夜观看| 欧美va亚洲va| 久久久久久免费网| 久久综合九色综合欧美就去吻| 欧美一区二区视频观看视频| 91精品国产手机| 91精品国产综合久久香蕉麻豆| 欧美精品一卡二卡| 91精品综合久久久久久| 欧美一区二区三区人| 精品少妇一区二区三区在线播放| 日韩女优av电影在线观看| 精品国产乱码久久久久久蜜臀| 精品美女被调教视频大全网站| 欧美大肚乱孕交hd孕妇| 国产亚洲欧美激情| 18欧美乱大交hd1984| 亚洲一区欧美一区| 丝袜美腿亚洲综合| 久久国产精品99久久久久久老狼| 精品亚洲成a人| 国产福利一区在线观看| 波多野结衣在线aⅴ中文字幕不卡| 成人一区二区三区| 欧美中文字幕不卡| 91精品国产全国免费观看| 久久影院午夜片一区| 毛片av中文字幕一区二区| 国产酒店精品激情| 99久久精品国产一区二区三区| 91亚洲精品久久久蜜桃| 欧美在线观看禁18| 日韩欧美在线影院| 中文天堂在线一区| 亚洲妇女屁股眼交7| 国产一区二区三区av电影| 91蜜桃婷婷狠狠久久综合9色| 欧美性生活影院| 久久久天堂av| 亚洲免费视频成人| 日韩精品福利网| 成人免费观看男女羞羞视频| 日本道免费精品一区二区三区| 欧美日韩国产综合草草| 久久午夜色播影院免费高清| 亚洲婷婷在线视频| 久久国产精品露脸对白| 成人精品电影在线观看| 91.麻豆视频| 中文字幕亚洲电影| 免费观看91视频大全| 成人激情开心网| 91精品国产乱| 亚洲天堂网中文字| 国产一区二区久久| 欧美三级中文字幕| 国产精品久久久久久久久免费樱桃| 亚洲一区二区三区免费视频| 国产iv一区二区三区| 欧美日韩成人激情| 国产精品国产三级国产a | 17c精品麻豆一区二区免费| 日韩vs国产vs欧美| 99re热这里只有精品视频| 久久精品人人做人人综合| 五月天欧美精品| 91在线观看一区二区| 久久免费精品国产久精品久久久久| 一区二区三区成人| 不卡在线观看av| 久久亚洲精品小早川怜子| 婷婷久久综合九色综合伊人色| 99精品久久只有精品| 国产日韩av一区| 国产精品亚洲а∨天堂免在线| 日韩视频免费观看高清完整版 | 久久香蕉国产线看观看99| 日本午夜精品视频在线观看 | 91福利在线免费观看| 综合激情成人伊人| 国产69精品久久777的优势| www久久精品| 美女网站在线免费欧美精品| 欧美日韩电影一区| 亚洲在线视频免费观看| 成人黄色大片在线观看| 久久精品人人爽人人爽| 久久精品免费观看| 日韩欧美色综合| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美日韩免费高清一区色橹橹| 亚洲综合999|