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

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

?? mainfrm.cpp

?? 基于C++語言的改進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;									//城市個數(shù)
double InitialTemperature = 0.0;					//初始溫度
double NowTemperature = 0.0;						//當(dāng)前迭代溫度
int	NowExternalIterNumber = 0;						//當(dāng)前外循環(huán)迭代次數(shù)
int NowInnerIterNumber = 0;							//當(dāng)前內(nèi)循環(huán)迭代次數(shù)
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 = "新的內(nèi)循環(huán)開始,當(dāng)前溫度為";
		strValue.Format("%10.4f",NowTemperature);
		strTemp += strValue;
		::SendMessage( ViewHWND, WYWM_INFOVIEWAPPENDINFO, (WPARAM)(&strTemp), (LPARAM)0 );
		strTemp = "當(dāng)前路徑為:";
		::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);	
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色婷婷亚洲婷婷| 日韩电影在线观看网站| 99久久精品国产毛片| 国产欧美综合色| 国产成人亚洲综合a∨猫咪| 国产亚洲精品久| 成人免费福利片| 亚洲欧洲日产国码二区| 色综合咪咪久久| 亚洲成人一区在线| 日韩一区二区三区电影在线观看 | 91国产丝袜在线播放| 一区二区三区日本| 91精品国产91久久久久久一区二区| 麻豆国产精品官网| 欧美激情综合在线| 色婷婷综合久色| 亚洲国产一二三| 欧美mv日韩mv亚洲| 成人免费视频免费观看| 一区二区三区不卡视频| 欧美一三区三区四区免费在线看 | 天堂一区二区在线免费观看| 91精品国产麻豆国产自产在线 | 色成年激情久久综合| 午夜视频一区二区| 久久久久久久久久看片| 91色视频在线| 欧美a一区二区| 中文字幕 久热精品 视频在线| 懂色中文一区二区在线播放| 亚洲色图一区二区| 日韩一区二区免费视频| 福利一区福利二区| 亚洲自拍偷拍图区| 久久日韩精品一区二区五区| 97se亚洲国产综合自在线不卡| 肉色丝袜一区二区| 欧美激情中文字幕一区二区| 欧美午夜一区二区三区免费大片| 久久99精品久久久久久| 亚洲婷婷综合久久一本伊一区| 777亚洲妇女| 波多野结衣亚洲| 丝袜美腿亚洲一区二区图片| 国产精品三级av| 欧美一区二区三区免费视频| hitomi一区二区三区精品| 午夜a成v人精品| 国产精品国产三级国产| 日韩一区和二区| 91小宝寻花一区二区三区| 青青草国产精品亚洲专区无| 亚洲欧洲无码一区二区三区| 日韩欧美的一区二区| 99热国产精品| 日韩一区二区在线观看视频播放| 亚洲精品综合在线| 久久久久综合网| 91 com成人网| 成人av影院在线| 精品制服美女丁香| 亚洲福利一二三区| 中文字幕一区二区三区av| 日韩欧美二区三区| 欧美亚日韩国产aⅴ精品中极品| 国产在线视频不卡二| 婷婷六月综合亚洲| 亚洲免费资源在线播放| 国产日韩欧美精品综合| 日韩亚洲欧美中文三级| 在线看国产日韩| 国产在线精品免费| 免费一级欧美片在线观看| 亚洲欧美激情在线| 国产女主播一区| 精品成人免费观看| 欧美一区二区国产| 欧美日韩国产高清一区二区三区| 91日韩精品一区| 高清国产一区二区| 男人的j进女人的j一区| 亚洲成av人片一区二区梦乃| 亚洲欧洲中文日韩久久av乱码| 国产无遮挡一区二区三区毛片日本| 日韩视频中午一区| 欧美丝袜丝交足nylons| 91免费小视频| 成人av免费在线观看| 国产一二精品视频| 美国毛片一区二区| 日本欧洲一区二区| 亚洲国产三级在线| 亚洲综合一二三区| 亚洲伦理在线免费看| 国产精品美女久久久久久久久 | 日韩欧美一区二区久久婷婷| 精品视频在线看| 欧美中文字幕一区二区三区亚洲| 99免费精品视频| 91在线视频在线| 成人国产精品免费| 国产一区91精品张津瑜| 国产一区二区三区视频在线播放| 久久国产日韩欧美精品| 伦理电影国产精品| 人人精品人人爱| 奇米777欧美一区二区| 奇米精品一区二区三区在线观看一 | 欧美xfplay| 精品美女在线播放| 欧美大片免费久久精品三p| 欧美成人三级电影在线| 精品国产污污免费网站入口| 日韩欧美一级在线播放| 精品国产髙清在线看国产毛片| 日韩欧美黄色影院| 欧美v亚洲v综合ⅴ国产v| 久久一二三国产| 欧美国产国产综合| 成人欧美一区二区三区在线播放| 亚洲欧洲精品一区二区三区不卡| 中文字幕在线观看一区| 亚洲乱码国产乱码精品精小说 | 亚洲综合成人在线| 午夜精品爽啪视频| 另类小说综合欧美亚洲| 日本不卡123| 免费成人小视频| 国产一二精品视频| 99久久精品免费| 欧美午夜视频网站| 久久久99精品免费观看| 国产拍欧美日韩视频二区| 综合久久综合久久| 国产精品久久久久影院| 亚洲综合小说图片| 麻豆久久久久久久| 成人中文字幕在线| 在线观看日韩电影| 欧美日韩国产区一| 精品久久免费看| 日本一区二区久久| 亚洲一区二区三区四区在线观看| 日韩国产欧美视频| 国产精品小仙女| 色8久久精品久久久久久蜜| 欧美精品三级在线观看| 精品对白一区国产伦| 国产精品不卡在线观看| 亚洲一区二区精品3399| 久久国产精品区| av亚洲精华国产精华精华| 欧美日韩亚洲丝袜制服| 精品国产一区二区三区久久久蜜月| 2023国产精品自拍| 亚洲蜜臀av乱码久久精品| 日本成人超碰在线观看| 成人免费视频免费观看| 欧美喷潮久久久xxxxx| 久久久久久一二三区| 亚洲欧美日韩国产成人精品影院 | 精品一区二区三区免费观看| eeuss鲁一区二区三区| 欧美蜜桃一区二区三区| 久久久久久久av麻豆果冻| 亚洲欧美激情在线| 男人的j进女人的j一区| 91蝌蚪porny成人天涯| 欧美二区三区91| 国产精品三级视频| 日本视频免费一区| 成人免费高清视频| 日韩色视频在线观看| 亚洲欧美偷拍三级| 九色综合国产一区二区三区| 91久久人澡人人添人人爽欧美| 香蕉影视欧美成人| 午夜欧美大尺度福利影院在线看 | 国产成人亚洲综合a∨婷婷图片| 欧美在线综合视频| 久久久久久日产精品| 日韩激情一二三区| 成a人片国产精品| 日韩欧美国产午夜精品| 怡红院av一区二区三区| 国产精品69毛片高清亚洲| 欧美裸体bbwbbwbbw| 中文字幕永久在线不卡| 久久 天天综合| 欧美日韩亚洲综合在线| 中文字幕一区二| 国产最新精品免费| 欧美日韩成人激情| 亚洲天堂成人在线观看| 国产一区二区精品久久91| 欧美日韩成人综合| 成人欧美一区二区三区| 国产高清久久久| 欧美一区二区精美|