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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? mainfrm.cpp

?? 模擬退火算法 模擬退火算法(Simulated Annealing,簡稱SA算法)是模擬加熱熔化的金屬的退火過程
?? 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;									//城市個數(shù)
double InitialTemperature = 0.0;					//初始溫度
double NowTemperature = 0.0;						//當前迭代溫度
int	NowExternalIterNumber = 0;						//當前外循環(huán)迭代次數(shù)
int NowInnerIterNumber = 0;							//當前內(nèi)循環(huán)迭代次數(shù)
int FileType;										//文件格式 0 無效格式 1 坐標格式 2 對稱距離矩陣格式
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問題";
	m_strTitle = "模擬退火算法求解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;
		BOOL readfilesucflg = TRUE;
		strFileName = pFileDialog->GetPathName();
		CStdioFile DataFile( strFileName, CFile::modeRead );
		CString strReadString;

		DataFile.ReadString(strReadString);
		if( strReadString == "coordinate" )
			FileType = 1;
		else if( strReadString == "distancematrix" )
			FileType = 2;
		else
			FileType = 0;

		if( FileType == 0 )
		{
			readfilesucflg = FALSE;
		}
		else
		{
			if( FileType == 1 )
			{
				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++;
				}
			}
			else if( FileType == 2 )
			{
				int nMatrixRow = 1;			//代表第幾個城市所對應的行
				int nMatrixCol = 1;
				int nMaxMatrixCol = -1;		//記錄第一行的列數(shù),后續(xù)行的列數(shù)如果不等于第一行,則數(shù)據(jù)文件錯誤
				CString strDistance;
				while( DataFile.ReadString(strReadString) )
				{
					strReadString.TrimLeft();
					strReadString.TrimRight();
	
					if( strReadString.IsEmpty() )
						continue;

					int nspace = 0;
					nMatrixCol = 1;
					while(1)
					{
						nspace = strReadString.Find(" ");
						SYCityDistance tmp_citydistance;
						if( nspace > 0 )
						{
							strDistance = strReadString.Left( nspace );
							tmp_citydistance.m_fDistance = atof( strDistance );
							tmp_citydistance.m_nFromCity = nMatrixRow;
							tmp_citydistance.m_nToCity = nMatrixCol;
							vecCityDistances.push_back( tmp_citydistance );

							strReadString = strReadString.Mid( nspace+1 );
							strReadString.TrimLeft();
						}
						else 
						{
							if( !strReadString.IsEmpty() )
							{
								strDistance = strReadString;
								tmp_citydistance.m_fDistance = atof( strDistance );
								tmp_citydistance.m_nFromCity = nMatrixRow;
								tmp_citydistance.m_nToCity = nMatrixCol;
								vecCityDistances.push_back( tmp_citydistance );

								strReadString.Empty();
								break;
							}
							else
								break;
						}
						nMatrixCol++;
					}

					if( nMaxMatrixCol < 0 )
						nMaxMatrixCol = nMatrixCol;
					else
					{
						if( nMaxMatrixCol != nMatrixCol )
						{
							readfilesucflg = FALSE;
							break;
						}
					}
	
					nMatrixRow++;
				}
			}
		}

		DataFile.Close();

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

			strTemp = "計算城市距離完成";
			pView->AddString( strTemp );
		}
		else
		{
			strTemp = "讀入數(shù)據(jù)文件錯誤";
			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 = "新的內(nèi)循環(huán)開始,當前溫度為";
		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一区二区三区免费野_久草精品视频
国产欧美精品一区二区三区四区| 欧美日韩国产高清一区二区三区 | 日本一区二区综合亚洲| 亚洲aaa精品| 成人精品鲁一区一区二区| 日韩一卡二卡三卡四卡| 亚洲视频1区2区| 国产精品一二三在| 日韩无一区二区| 亚洲成人免费视| 91啪在线观看| 中文久久乱码一区二区| 国产在线精品一区二区三区不卡 | 欧美色图免费看| 中文字幕日韩精品一区| 国产精品资源网站| 日韩免费高清视频| 五月激情丁香一区二区三区| 色偷偷88欧美精品久久久| 中文字幕成人av| 国产成人综合自拍| 久久婷婷色综合| 卡一卡二国产精品| 日韩欧美国产电影| 秋霞电影一区二区| 欧美精品一卡二卡| 一区二区日韩av| 91豆麻精品91久久久久久| 中文字幕亚洲欧美在线不卡| 岛国一区二区三区| 国产精品乱码久久久久久| 国产福利视频一区二区三区| 精品国产乱码久久久久久老虎| 秋霞电影一区二区| 日韩一区二区三区av| 日本伊人色综合网| 欧美一卡二卡三卡四卡| 天堂在线亚洲视频| 欧美丰满少妇xxxbbb| 日韩国产在线一| 51精品秘密在线观看| 轻轻草成人在线| 精品乱人伦一区二区三区| 久久精品国产成人一区二区三区 | 日本一区免费视频| www.亚洲精品| 中文字幕制服丝袜一区二区三区 | 日本vs亚洲vs韩国一区三区二区 | 日韩欧美在线综合网| 六月丁香婷婷色狠狠久久| 欧美第一区第二区| 韩国女主播一区| 国产午夜精品久久| 国产精品久久久久婷婷| 成人精品一区二区三区中文字幕| 亚洲国产精品成人久久综合一区| 成人的网站免费观看| 亚洲图片激情小说| 欧美综合一区二区三区| 首页国产丝袜综合| 精品剧情在线观看| 成人免费黄色大片| 一区二区在线看| 欧美日韩在线直播| 久久激情五月激情| 日本一区二区三区电影| 色婷婷久久综合| 日韩专区欧美专区| 久久久久久99精品| 91年精品国产| 天堂蜜桃一区二区三区| 久久尤物电影视频在线观看| 成人h精品动漫一区二区三区| 亚洲久草在线视频| 91精品国模一区二区三区| 国产乱色国产精品免费视频| 亚洲欧美另类久久久精品| 3d成人h动漫网站入口| 国产一区二三区| 亚洲天堂精品在线观看| 9191久久久久久久久久久| 国产麻豆成人精品| 一区二区三区影院| 精品少妇一区二区三区免费观看| 成人深夜福利app| 性做久久久久久久免费看| 久久亚洲一区二区三区明星换脸| 99国产精品久久久久久久久久久| 午夜久久久久久久久久一区二区| 国产亚洲精品免费| 色久优优欧美色久优优| 精品一区二区三区蜜桃| 亚洲欧洲av一区二区三区久久| 欧美日韩的一区二区| 东方欧美亚洲色图在线| 日韩电影在线一区二区三区| 欧美激情综合五月色丁香| 欧美日韩mp4| 成人动漫中文字幕| 奇米影视一区二区三区| 亚洲欧美日韩国产中文在线| 精品久久五月天| 欧美三级视频在线播放| 懂色av一区二区夜夜嗨| 免费日本视频一区| 亚洲精品美国一| 久久久久久久久久久久久久久99 | 成人国产精品免费观看| 麻豆国产欧美日韩综合精品二区| 中文字幕一区在线观看| 精品少妇一区二区三区日产乱码 | 国产精品视频免费看| 777xxx欧美| 99久久99久久精品免费看蜜桃| 精品一区二区av| 欧美色网站导航| 成人一级片网址| 久久精品国产99国产精品| 亚洲网友自拍偷拍| 亚洲视频一区二区在线观看| 久久久综合视频| 日韩一区二区在线观看视频| 欧美日韩综合色| 色八戒一区二区三区| 粉嫩aⅴ一区二区三区四区 | 午夜精品免费在线观看| 亚洲视频 欧洲视频| 欧美激情一区三区| 26uuu成人网一区二区三区| 欧美精品在线一区二区| 欧美中文字幕一区二区三区亚洲 | 久久精品国产免费| 日韩黄色免费网站| 午夜视频在线观看一区二区三区 | 久久久久国产精品人| 日韩精品一区二区三区蜜臀| 欧美日本高清视频在线观看| 日本福利一区二区| 91免费观看视频在线| 成人高清免费在线播放| 成人做爰69片免费看网站| 国产黄色精品网站| 国产精品自在欧美一区| 国产一区二区91| 久久99精品国产麻豆婷婷 | 亚洲人xxxx| 国产精品高潮久久久久无| 国产日本一区二区| 欧美激情在线免费观看| 国产精品麻豆久久久| 国产精品―色哟哟| 国产精品国产三级国产普通话蜜臀 | 丁香一区二区三区| 国产成人在线视频网址| 国产一区二三区好的| 国产精品亚洲一区二区三区妖精| 国产在线精品一区二区夜色| 国产毛片精品视频| 丁香激情综合国产| 国v精品久久久网| 东方欧美亚洲色图在线| www.欧美日韩国产在线| 91啪亚洲精品| 欧美视频在线观看一区二区| 欧美高清激情brazzers| 56国语精品自产拍在线观看| 日韩视频免费观看高清完整版在线观看 | 在线中文字幕一区| 欧美色国产精品| 欧美一区二区日韩| 精品国产1区二区| 国产欧美一区二区三区鸳鸯浴 | 国产精品免费视频观看| proumb性欧美在线观看| 一本色道久久综合亚洲精品按摩| 欧美制服丝袜第一页| 69p69国产精品| 欧美成人欧美edvon| 国产丝袜在线精品| 亚洲免费色视频| 五月天一区二区三区| 久久疯狂做爰流白浆xx| 成人一区二区三区视频在线观看| 色综合色狠狠综合色| 欧美日韩午夜在线视频| 欧美成人三级电影在线| 欧美激情中文字幕一区二区| 一区二区在线免费观看| 免费xxxx性欧美18vr| 国产成人福利片| 色美美综合视频| 欧美一级日韩免费不卡| 久久久精品中文字幕麻豆发布| 国产精品拍天天在线| 亚洲国产cao| 国产一区亚洲一区| 99精品1区2区| 日韩欧美国产综合一区| 国产精品久久久久婷婷| 日韩制服丝袜先锋影音|