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

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

?? mainfrm.cpp

??  針對基于遺傳算法的TSP 問題求解, 嘗試了多種遺傳操作, 分析了這些操作在遺傳算法中的作用, 討論了基因片段保序在利用遺傳算法求解TSP 問題中的重要性.
?? CPP
字號:
// MainFrm.cpp : implementation of the CMainFrame class
//

#include "stdafx.h"
#include "TspSA.h"
#include "TspSADoc.h"
#include "TspSAView.h"
#include "math.h"
#include "MainFrm.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

//似乎必須放在下面,如果把這些全局變量定義放在最頂處則報錯 why?
std::vector<SYCity> vecCitys;						//城市列表
std::vector<SYCityDistance> vecCityDistances;		//城市距離列表
int CityNumber = 0;									//城市個數
double InitialTemperature = 0.0;					//初始溫度
double NowTemperature = 0.0;						//當前迭代溫度
int	NowExternalIterNumber = 0;						//當前外循環迭代次數
int NowInnerIterNumber = 0;							//當前內循環迭代次數
BOOL IsComputing = FALSE;

/////////////////////////////////////////////////////////////////////////////
// CMainFrame

IMPLEMENT_DYNCREATE(CMainFrame, CFrameWnd)

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
	//{{AFX_MSG_MAP(CMainFrame)
	ON_WM_CREATE()
	ON_COMMAND(ID_FILE_OPEN, OnFileOpen)
	ON_COMMAND(ID_FILE_START, OnFileStart)
	ON_UPDATE_COMMAND_UI(ID_FILE_START, OnUpdateFileStart)
	ON_UPDATE_COMMAND_UI(ID_FILE_OPEN, OnUpdateFileOpen)
	ON_COMMAND(ID_APP_GETCODE, OnAppGetcode)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

static UINT indicators[] =
{
	ID_SEPARATOR,           // status line indicator
};

/////////////////////////////////////////////////////////////////////////////
// CMainFrame construction/destruction

CMainFrame::CMainFrame()
{
}

CMainFrame::~CMainFrame()
{
}

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
	if (CFrameWnd::OnCreate(lpCreateStruct) == -1)
		return -1;
	
	if (!m_wndStatusBar.Create(this) ||
		!m_wndStatusBar.SetIndicators(indicators,
		  sizeof(indicators)/sizeof(UINT)))
	{
		TRACE0("Failed to create status bar\n");
		return -1;      // fail to create
	}

	// TODO: Delete these three lines if you don't want the toolbar to
	//  be dockable

	return 0;
}

BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs)
{
	cs.style &= ~FWS_ADDTOTITLE;
	if( !CFrameWnd::PreCreateWindow(cs) )
		return FALSE;
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	m_strTitle = "www.huisoft.com.cn  模擬退火算法求解TSP問題";
	return TRUE;
}

/////////////////////////////////////////////////////////////////////////////
// CMainFrame diagnostics

#ifdef _DEBUG
void CMainFrame::AssertValid() const
{
	CFrameWnd::AssertValid();
}

void CMainFrame::Dump(CDumpContext& dc) const
{
	CFrameWnd::Dump(dc);
}

#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMainFrame message handlers


void CMainFrame::OnFileOpen() 
{
	CString strFileName;
	char szFilter[200];
	strcpy( szFilter, "TXT Files (*.txt)|*.txt||" );
	CFileDialog *pFileDialog;
	pFileDialog = new CFileDialog( TRUE, 
								NULL, 
								NULL, 
								OFN_HIDEREADONLY,
								szFilter,
								this );
	if( IDOK == pFileDialog->DoModal() )
	{
		CTspSAView *pView = (CTspSAView*)GetActiveView();
		ClearSA();
		pView->ClearInfos();
		
		CString strValue, strTemp;
		strFileName = pFileDialog->GetPathName();
		CStdioFile DataFile( strFileName, CFile::modeRead );
		CString strReadString;
		int ncityindex = 1;
		while( DataFile.ReadString(strReadString) ) 
		{
			strReadString.TrimLeft();
			strReadString.TrimRight();

			CString cityName, citycodx, citycody;
			int nspace = 0;
			nspace = strReadString.Find(" ");
			if( nspace > 0 )
				cityName = strReadString.Left( nspace );

			strReadString = strReadString.Mid( nspace+1 );
			nspace = strReadString.Find(" ");
			if( nspace > 0 )
				citycodx = strReadString.Left( nspace );

			strReadString = strReadString.Mid( nspace+1 );
			citycody = strReadString;

			SYCity tmpCity;
			tmpCity.m_strName = "城市 "+cityName;
			tmpCity.m_nIndex = ncityindex;
			tmpCity.m_Coordinate.m_fcodx = atof( citycodx );
			tmpCity.m_Coordinate.m_fcody = atof( citycody );

			vecCitys.push_back( tmpCity );

			ncityindex++;
		}
		DataFile.Close();

		InitialSA();
		strTemp = "共讀入城市信息";
		strValue.Format("%d",CityNumber);
		strTemp += strValue;
		strTemp += "個";
		pView->AddString( strTemp );

		strTemp = "計算城市距離完成";
		pView->AddString( strTemp );
	}	

	delete pFileDialog;
}

UINT SACompution(LPVOID pParam)
{
	IsComputing = TRUE;

	srand( (unsigned)time( NULL ) );

	CFile cityfile("C:\\sacitysfile.txt", CFile::modeCreate|CFile::modeWrite);
	CFile iterfile("C:\\saitersfile.txt", CFile::modeCreate|CFile::modeWrite);

	CString strTemp, strValue;
	CTspSAView *pView = (CTspSAView*)pParam;
	HWND ViewHWND = pView->GetSafeHwnd();

	strTemp = "開始計算";
	::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );

	SYRouter ResultRouter( NowTemperature, NowExternalIterNumber, NowInnerIterNumber );

	strTemp = "生成初始路徑:";
	::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );
	strTemp = FormRouterString( ResultRouter );
	::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );

	while(1)
	{
		strTemp = "新的內循環開始,當前溫度為";
		strValue.Format("%10.4f",NowTemperature);
		strTemp += strValue;
		::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );
		strTemp = "當前路徑為:";
		::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );
		strTemp = FormRouterString( ResultRouter );
		::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );

		double deltatotaldis = 0.0;
		while(1)
		{
			SYRouter SelRouter( ResultRouter.m_CityRouter, NowTemperature, NowExternalIterNumber, NowInnerIterNumber );

			deltatotaldis = SelRouter.m_fTotalDistance-ResultRouter.m_fTotalDistance;
			if( deltatotaldis <= 0.0 )
			{
				ResultRouter = SelRouter;
			}
			else
			{
				double chgprobability = exp( -(deltatotaldis/NowTemperature) );
				int randomnum = rand();
				double random = ((double)(randomnum%10000))/10000.0;
				if(chgprobability > random )
				{
					ResultRouter = SelRouter;
				}
			}

			if( JudgeOverInnerLoop(0) )
			{
				break;
			}
			else
				NowInnerIterNumber++;
		}

		if( JudgeOverExternalLoop(0) )
			break;
		else
		{
			NowTemperature = CountDownTemperature( NowTemperature, 0 );
			NowExternalIterNumber++;
			NowInnerIterNumber = 0;

			strValue.Format("%d %.4f\n",NowExternalIterNumber, ResultRouter.m_fTotalDistance );
			iterfile.Write( strValue, strValue.GetLength() );

		}
	}

	strTemp = "計算得最佳路徑為:";
	::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );
	strTemp = FormRouterString( ResultRouter );
	::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );
	
	GetRouterFileString( ResultRouter, strTemp );
	cityfile.Write( strTemp, strTemp.GetLength() );

	cityfile.Close();
	iterfile.Close();

	IsComputing = FALSE;
	return 0;
}

void CMainFrame::OnFileStart() 
{
	CTspSAView *pView = (CTspSAView*)GetActiveView();
	AfxBeginThread( SACompution, (LPVOID)pView );
}

void CMainFrame::OnUpdateFileStart(CCmdUI* pCmdUI) 
{
	if( vecCityDistances.empty() || IsComputing )
		pCmdUI->Enable(FALSE);
	else
		pCmdUI->Enable(TRUE);
}

void CMainFrame::OnUpdateFileOpen(CCmdUI* pCmdUI) 
{
	if( IsComputing )
		pCmdUI->Enable(FALSE);
	else
		pCmdUI->Enable(TRUE);
}

void CMainFrame::OnAppGetcode() 
{
	CString strTemp;
	strTemp.LoadString(IDS_HELP_HOMEPAGE);
	::ShellExecute(NULL, "open", strTemp, NULL, NULL, SW_SHOWNORMAL);	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲婷婷综合久久一本伊一区| 成人一级黄色片| 91电影在线观看| 日韩伦理免费电影| 91天堂素人约啪| 亚洲手机成人高清视频| 99在线视频精品| 亚洲欧美日韩国产一区二区三区 | 舔着乳尖日韩一区| 欧美性xxxxxxxx| 三级成人在线视频| 欧美一区二区三区免费大片 | 日本视频中文字幕一区二区三区| 欧美日韩亚洲不卡| 日本不卡视频在线观看| 日韩免费看网站| 国产福利一区在线观看| 中文字幕一区二区三区在线播放 | 国产亚洲成aⅴ人片在线观看| 国产91色综合久久免费分享| 中日韩av电影| 欧美在线小视频| 麻豆专区一区二区三区四区五区| 精品国产一区二区三区av性色| 国产精品亚洲视频| 亚洲欧美日韩人成在线播放| 欧美日韩不卡视频| 国产一区二区三区美女| 国产欧美日韩三区| 欧美做爰猛烈大尺度电影无法无天| 天堂成人国产精品一区| wwwwxxxxx欧美| 99re8在线精品视频免费播放| 婷婷久久综合九色综合伊人色| 2023国产精品| 在线亚洲一区观看| 狠狠色丁香婷婷综合| 国产精品白丝在线| 欧美成人vr18sexvr| av一二三不卡影片| 奇米色777欧美一区二区| 中文字幕 久热精品 视频在线| 欧美天天综合网| 国产乱人伦偷精品视频不卡| 亚洲精品国产第一综合99久久 | 9191国产精品| 成人激情免费视频| 青青草国产成人99久久| 国产精品二三区| 日韩欧美一区在线观看| 色一情一伦一子一伦一区| 久久精品国产999大香线蕉| 亚洲色欲色欲www| www久久精品| 欧美久久久久免费| 色狠狠综合天天综合综合| 狠狠色丁香久久婷婷综合_中| 亚洲黄色av一区| 国产精品乱人伦| 精品久久久久久久久久久久久久久久久| 91美女片黄在线| 成人综合在线网站| 国产麻豆精品久久一二三| 五月天久久比比资源色| 亚洲激情中文1区| 亚洲国产高清在线观看视频| 欧美一区二区三区性视频| 欧美色倩网站大全免费| 91视频.com| 9i在线看片成人免费| 国产激情一区二区三区四区| 日本不卡的三区四区五区| 亚洲一区电影777| 一区二区在线观看免费| 成人欧美一区二区三区小说 | 亚洲精品国产一区二区三区四区在线 | 国产成a人亚洲精品| 蓝色福利精品导航| 蜜桃av一区二区在线观看| 亚洲va欧美va天堂v国产综合| 亚洲欧美日韩久久| 亚洲精品ww久久久久久p站| 18欧美乱大交hd1984| 丝袜美腿成人在线| 亚欧色一区w666天堂| 亚洲电影第三页| 亚洲午夜精品一区二区三区他趣| 综合网在线视频| 亚洲猫色日本管| 亚洲免费观看高清完整版在线观看熊 | 日韩理论片一区二区| 中文字幕中文字幕一区| 国产精品免费视频一区| 国产精品久久久久久久久晋中| 国产精品区一区二区三| 国产精品你懂的在线欣赏| 国产清纯白嫩初高生在线观看91| 26uuu色噜噜精品一区| 久久久久久综合| 中文字幕第一区二区| 国产精品初高中害羞小美女文| 国产精品久久久久久久久果冻传媒 | 欧美激情自拍偷拍| 中文字幕五月欧美| 一区二区三区产品免费精品久久75| 伊人婷婷欧美激情| 石原莉奈在线亚洲三区| 国产综合色产在线精品| 风间由美一区二区三区在线观看| 99久久er热在这里只有精品15| 91免费视频观看| 最新国产精品久久精品| 亚洲一区在线视频| 丝袜美腿亚洲一区| 国产高清精品在线| 色国产综合视频| 欧美精品色综合| 精品国产一区二区三区不卡| 国产精品日韩精品欧美在线| 亚洲免费观看视频| 日本va欧美va精品发布| 国产成人日日夜夜| 91福利精品视频| 337p粉嫩大胆噜噜噜噜噜91av | 色婷婷国产精品| 欧美一级理论片| 中文字幕一区二区不卡| 日韩和欧美的一区| 国产成人在线免费观看| 欧美午夜宅男影院| 久久精品免视看| 亚洲动漫第一页| 国产a区久久久| 欧美精品国产精品| 中文字幕不卡的av| 美女国产一区二区三区| 成人app在线| 欧美一二三四在线| 亚洲免费在线视频一区 二区| 青青草成人在线观看| 色av成人天堂桃色av| 久久夜色精品一区| 午夜精品福利一区二区蜜股av| 成人综合婷婷国产精品久久 | 粉嫩aⅴ一区二区三区四区| 欧美乱妇20p| 亚洲欧美另类在线| 国产高清不卡一区| 日韩欧美高清在线| 亚洲一区二区三区中文字幕 | 日日骚欧美日韩| 波多野结衣在线一区| 欧美精品一区二区三区视频| 亚洲一二三区视频在线观看| 国产激情一区二区三区四区| 337p亚洲精品色噜噜| 亚洲精品久久嫩草网站秘色| 国产成人小视频| 欧美v国产在线一区二区三区| 亚洲永久免费av| 色哟哟国产精品| 亚洲欧洲精品成人久久奇米网| 欧美日韩一区二区欧美激情| 综合久久久久久久| 成年人午夜久久久| 国产精品私人影院| 成人一区二区三区在线观看| 久久综合网色—综合色88| 看电影不卡的网站| 欧美一级电影网站| 麻豆精品精品国产自在97香蕉| 欧美精品一级二级三级| 午夜伦理一区二区| 欧美人妖巨大在线| 视频一区视频二区中文字幕| 欧美在线观看一二区| 亚洲国产日日夜夜| 欧美日韩免费不卡视频一区二区三区| 亚洲欧美电影院| 91国产成人在线| 午夜精品久久久久久久99水蜜桃| 欧美区视频在线观看| 午夜伦欧美伦电影理论片| 欧美人与z0zoxxxx视频| 日本欧美肥老太交大片| 日韩一区二区三| 精品一区二区三区久久| 欧美成人在线直播| 国产jizzjizz一区二区| **性色生活片久久毛片| 一本大道久久a久久综合婷婷| 一区二区三区视频在线看| 欧美视频一区二区三区四区 | 亚洲天堂久久久久久久| 91视频免费播放| 视频一区二区三区入口| 精品av综合导航| 成人激情综合网站| 有坂深雪av一区二区精品| 欧美人与性动xxxx|