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

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

?? mainfrm.cpp

?? 首先介紹模擬退火算法
?? 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一区二区三区免费野_久草精品视频
色偷偷一区二区三区| 一本大道久久a久久精二百| 国产精品对白交换视频| 欧美日韩国产一区| 国产91丝袜在线观看| 亚洲超碰97人人做人人爱| 欧美国产日韩亚洲一区| 欧美精品第1页| 91一区二区在线| 国产一区激情在线| 午夜精品久久久久久久| 亚洲欧美日韩电影| 国产午夜精品一区二区 | 蜜臀久久99精品久久久久久9 | 亚洲精品一区二区精华| 91激情五月电影| 国产成人精品影院| 男女性色大片免费观看一区二区| 亚洲三级免费观看| 中文一区二区在线观看| 精品国产99国产精品| 欧美日韩国产美| 91福利在线播放| 99re6这里只有精品视频在线观看| 国产一区福利在线| 精品一区在线看| 日韩电影免费在线看| 亚洲资源在线观看| 一区二区三区在线免费视频| 国产精品久久久一区麻豆最新章节| 精品国产一区a| 日韩免费一区二区| 日韩一区二区免费电影| 欧美乱妇15p| 欧美日韩aaa| 欧美男人的天堂一二区| 欧美日韩你懂得| 欧美精品一二三| 777色狠狠一区二区三区| 欧美日韩综合不卡| 欧美人伦禁忌dvd放荡欲情| 欧美日韩综合在线免费观看| 欧美日韩中文字幕一区二区| 欧美日韩视频在线一区二区| 欧美日韩成人综合天天影院| 欧美一区午夜精品| 欧美不卡一区二区三区四区| 精品国产sm最大网站免费看| 国产亚洲制服色| 中文成人av在线| 亚洲色图20p| 亚洲图片欧美综合| 午夜免费久久看| 久久福利视频一区二区| 国产曰批免费观看久久久| 国产91精品一区二区| av在线播放一区二区三区| 色婷婷综合久久久中文字幕| 欧美日韩国产首页在线观看| 日韩精品最新网址| 日本一二三不卡| 亚洲欧美日韩国产另类专区| 亚洲成人福利片| 精品一区二区三区免费毛片爱 | 日本特黄久久久高潮| 免费美女久久99| 国产成人av电影在线| 色综合天天综合在线视频| 欧美精品日韩一本| 久久久国产精华| 一级女性全黄久久生活片免费| 日本不卡在线视频| 国产电影一区二区三区| 日本韩国精品一区二区在线观看| 777亚洲妇女| 国产精品美女久久久久aⅴ国产馆| 亚洲男人都懂的| 美国十次了思思久久精品导航| 成人亚洲精品久久久久软件| 欧美色爱综合网| 久久亚洲精精品中文字幕早川悠里 | 国产精品污网站| 亚洲国产综合视频在线观看| 国产一区二区网址| 91极品视觉盛宴| 国产午夜亚洲精品羞羞网站| 亚洲国产精品麻豆| 成人在线综合网| 69久久99精品久久久久婷婷| 国产精品黄色在线观看| 奇米888四色在线精品| aaa欧美日韩| 精品理论电影在线观看| 一区二区三区欧美在线观看| 国产精品一区二区不卡| 欧美日韩精品一区二区三区蜜桃 | 久久欧美中文字幕| 亚洲国产成人porn| 成人高清视频免费观看| 这里只有精品视频在线观看| 亚洲人成网站精品片在线观看| 久久99精品久久久久久久久久久久| 97精品国产97久久久久久久久久久久| 91精品国产一区二区三区蜜臀| 中文字幕亚洲一区二区av在线| 久久99久久99小草精品免视看| 欧美性视频一区二区三区| 国产精品美女视频| 国产大片一区二区| 日韩一区二区免费高清| 性感美女久久精品| 91黄色激情网站| 中文字幕一区二区在线观看| 久久国产成人午夜av影院| 777色狠狠一区二区三区| 亚洲一区二区三区四区中文字幕| 懂色av一区二区三区免费看| 欧美精品一区二区三区一线天视频| 日日骚欧美日韩| 日本道色综合久久| 中文字幕一区二区三区在线观看| 国产精品一品视频| 久久毛片高清国产| 激情伊人五月天久久综合| 91精品国产综合久久福利软件 | 青椒成人免费视频| 欧美精品久久99| 日韩精品电影一区亚洲| 欧美日韩一级片网站| 亚洲精品国产一区二区精华液| 99精品欧美一区二区三区小说 | 午夜欧美大尺度福利影院在线看| 一本久久精品一区二区| 亚洲人成在线播放网站岛国| 91在线视频18| 亚洲激情图片qvod| 欧美在线免费观看亚洲| 一区二区三区四区不卡视频| 欧美亚洲动漫精品| 亚洲成av人片| 欧美一级淫片007| 久久99这里只有精品| 精品999在线播放| 国产精品性做久久久久久| 久久久久国产一区二区三区四区| 国产成人免费在线视频| 国产精品的网站| 在线观看一区不卡| 午夜不卡在线视频| 日韩欧美成人激情| 国产成人精品www牛牛影视| 国产精品久久久久久久久果冻传媒| a4yy欧美一区二区三区| 亚洲国产毛片aaaaa无费看 | av中文字幕一区| 一区二区三区不卡视频| 欧美日本在线一区| 韩国理伦片一区二区三区在线播放| 国产三级三级三级精品8ⅰ区| 国产成人精品亚洲777人妖| 亚洲色图一区二区| 欧美日韩一级黄| 久久精品国产99| 亚洲国产高清在线观看视频| 在线亚洲免费视频| 蜜臀久久99精品久久久画质超高清| 欧美精品一区二区久久婷婷 | 成人av影视在线观看| 国产精品福利一区二区三区| 在线免费观看日韩欧美| 日本不卡123| 国产精品久久免费看| 欧美性欧美巨大黑白大战| 久久不见久久见免费视频7| 国产精品日产欧美久久久久| 91福利小视频| 国产精品99久| 亚洲成人动漫在线免费观看| 国产日韩精品久久久| 在线观看国产一区二区| 精品一区二区三区视频在线观看| 18成人在线视频| 欧美成人一区二区| 一本一道综合狠狠老| 久久99国产精品免费网站| 亚洲乱码国产乱码精品精的特点| 日韩三级在线观看| 99久久久精品| 久久激情五月激情| 亚洲一区二区三区四区在线| 国产日韩欧美一区二区三区综合| 欧美色窝79yyyycom| 成人一二三区视频| 狂野欧美性猛交blacked| 亚洲免费看黄网站| 国产欧美日韩视频在线观看| 91精品国产综合久久福利软件| 91丨porny丨户外露出| 国产又粗又猛又爽又黄91精品| 午夜视频一区二区|