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

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

?? mainfrm.cpp

?? 從其它網站上下載的用VC++編制的模擬退火算法求解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一区二区三区免费野_久草精品视频
成人黄色在线网站| 日韩欧美国产一二三区| 欧美一区二区三区思思人| 国产欧美日韩卡一| 日韩专区欧美专区| 色婷婷国产精品综合在线观看| 日韩欧美成人一区| 亚洲一区在线免费观看| 成人一二三区视频| 久久综合资源网| 日本欧美在线看| 精品视频在线免费| 亚洲黄色性网站| 成人免费av在线| 国产视频一区二区在线| 免费黄网站欧美| 欧美日韩亚洲综合一区| 亚洲与欧洲av电影| 91亚洲精品乱码久久久久久蜜桃| 久久久久久一级片| 狂野欧美性猛交blacked| 欧美精品在线观看一区二区| 亚洲一区二区在线观看视频| 9久草视频在线视频精品| 国产视频亚洲色图| 国产高清一区日本| 久久久精品tv| 成人小视频免费在线观看| 精品处破学生在线二十三| 久久激五月天综合精品| 日韩三级高清在线| 激情综合色播激情啊| 日韩精品在线网站| 久草这里只有精品视频| 日韩欧美中文一区| 国产一区在线不卡| 久久精品亚洲乱码伦伦中文| 国产在线精品免费| 国产嫩草影院久久久久| 成人激情av网| 亚洲精品自拍动漫在线| 日本丰满少妇一区二区三区| 亚洲午夜精品网| 91精品一区二区三区在线观看| 青青草成人在线观看| 日韩一区二区不卡| 国产精品乡下勾搭老头1| 欧美激情一区二区| 色婷婷国产精品综合在线观看| 亚洲香肠在线观看| 日韩限制级电影在线观看| 韩国av一区二区三区在线观看| 久久精品亚洲精品国产欧美kt∨ | 椎名由奈av一区二区三区| jlzzjlzz欧美大全| 亚洲一区精品在线| 欧美一区二区三区在线观看| 狠狠色丁香久久婷婷综合_中| 久久精品一区二区三区不卡| 99久久免费视频.com| 国产一区不卡在线| 国产精品久久久一本精品 | 美女一区二区在线观看| 国产日产欧美一区二区三区| 91在线免费看| 麻豆一区二区三| 国产精品盗摄一区二区三区| 欧美在线不卡视频| 国产在线精品免费| 亚洲一线二线三线久久久| 久久免费视频一区| 欧美色中文字幕| 国产激情91久久精品导航| 亚洲精品欧美专区| 久久久久久久电影| 欧美在线观看视频在线| 国产一区二区三区电影在线观看| 亚洲黄一区二区三区| 久久影院午夜片一区| 日本韩国一区二区| 国产精品1024| 日本色综合中文字幕| 亚洲欧美色一区| 欧美精品一区二区三区蜜桃| 91国偷自产一区二区三区成为亚洲经典 | 日韩欧美一级精品久久| 色综合天天做天天爱| 九一久久久久久| 亚洲国产精品久久久久婷婷884 | 国产精品资源网| 亚洲成人动漫精品| 国产精品乱人伦| 久久久无码精品亚洲日韩按摩| 7777女厕盗摄久久久| 色哟哟一区二区| 成人av片在线观看| 久久99精品久久久| 视频一区欧美日韩| 亚洲黄网站在线观看| 中文欧美字幕免费| 久久久亚洲高清| 精品久久久三级丝袜| 91精品国产免费| 777奇米成人网| 欧美中文字幕不卡| 99re这里都是精品| 国产黄色91视频| 国产成人午夜电影网| 国模少妇一区二区三区| 久久精品国产网站| 国内精品伊人久久久久影院对白| 天天综合天天综合色| 亚洲午夜日本在线观看| 亚洲精品国产高清久久伦理二区| 中文字幕精品三区| 欧美激情综合五月色丁香| 久久精品视频在线免费观看| 2020国产精品自拍| 欧美精品一区二| 久久精品在线观看| 国产精品色呦呦| 亚洲人妖av一区二区| 亚洲精品一卡二卡| 亚洲国产精品久久人人爱 | 欧美肥胖老妇做爰| 在线不卡免费欧美| 日韩欧美二区三区| 久久精品人人做人人综合| 国产日韩欧美综合在线| 欧美高清在线精品一区| 国产精品久久久久一区二区三区| 亚洲欧美在线视频观看| 亚洲精品第1页| 日韩成人一区二区| 国产麻豆视频一区| 91网站在线观看视频| 欧美日韩在线播放三区| 欧美一区二区三区电影| 2023国产精品| 一区二区久久久| 麻豆精品久久久| 岛国精品一区二区| 欧美性生活久久| 精品国产凹凸成av人导航| 国产精品五月天| 亚洲高清不卡在线观看| 玖玖九九国产精品| 9色porny自拍视频一区二区| 欧美色爱综合网| 国产亚洲一区二区三区| 一区二区三区国产豹纹内裤在线| 石原莉奈在线亚洲三区| 国产成人精品亚洲777人妖 | 亚洲男同1069视频| 精品一区二区在线看| 一本大道久久精品懂色aⅴ | 欧美二区三区的天堂| 国产欧美一区二区精品婷婷| 一区二区三区不卡在线观看| 九一九一国产精品| 91精品1区2区| 欧美国产日产图区| 日韩成人一级大片| 99久久精品国产一区| 日韩精品在线一区二区| 亚洲日本丝袜连裤袜办公室| 精品在线播放免费| 欧美日韩卡一卡二| 亚洲欧洲精品一区二区三区 | 亚洲福利电影网| 99视频精品免费视频| 欧美大片一区二区三区| 亚洲国产一区二区三区青草影视 | 美女尤物国产一区| 欧美色图在线观看| 日韩理论在线观看| 国产99久久久国产精品| 日韩一区二区影院| 亚洲一级二级三级| 91麻豆国产福利在线观看| 久久免费电影网| 裸体一区二区三区| 欧美日韩在线三区| 一区二区三区小说| 99精品国产视频| 国产欧美一区二区三区沐欲| 捆绑调教一区二区三区| 欧美一区二区网站| 午夜伦理一区二区| 欧美午夜一区二区三区免费大片| 中文字幕佐山爱一区二区免费| 国产精品69久久久久水密桃| 日韩美一区二区三区| 男人的j进女人的j一区| 欧美肥大bbwbbw高潮| 天堂成人国产精品一区| 91精品婷婷国产综合久久竹菊| 亚洲国产精品久久久男人的天堂| 欧美伊人久久久久久久久影院| 亚洲欧美一区二区不卡|