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

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

?? ant_testdlg.cpp

?? 蟻群算法的程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// ant_testDlg.cpp : implementation file
//

#include "stdafx.h"
#include "ant_test.h"
#include "ant_testDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
#include <iostream.h>
int cur_iter;
double curbest[1000];
double aver1[1000];
/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CAnt_testDlg dialog

CAnt_testDlg::CAnt_testDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CAnt_testDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CAnt_testDlg)
	m_edit2 = 20;
	m_edit3 = 500;
	m_edit4 = 0.2;
	m_edit5 = 0.2;
	m_edit6 = 0.8;
	m_edit7 = 0.01;
	m_edit8 = 20;
	m_edit9 = 0.0;
	m_edit10 = 0.0;
	m_edit11 = 240;
	m_edit12 = 0;
	m_edit13 = 0.0;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CAnt_testDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAnt_testDlg)
	DDX_Text(pDX, IDC_EDIT2, m_edit2);
	DDX_Text(pDX, IDC_EDIT3, m_edit3);
	DDX_Text(pDX, IDC_EDIT4, m_edit4);
	DDX_Text(pDX, IDC_EDIT5, m_edit5);
	DDX_Text(pDX, IDC_EDIT6, m_edit6);
	DDX_Text(pDX, IDC_EDIT7, m_edit7);
	DDX_Text(pDX, IDC_EDIT8, m_edit8);
	DDX_Text(pDX, IDC_EDIT9, m_edit9);
	DDX_Text(pDX, IDC_EDIT10, m_edit10);
	DDX_Text(pDX, IDC_EDIT11, m_edit11);
	DDX_Text(pDX, IDC_EDIT12, m_edit12);
	DDX_Text(pDX, IDC_EDIT13, m_edit13);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAnt_testDlg, CDialog)
	//{{AFX_MSG_MAP(CAnt_testDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON1, Onend)
	ON_WM_CANCELMODE()
	ON_WM_TIMER()
	ON_BN_CLICKED(IDC_BUTTON2, Onrun)
	ON_BN_CLICKED(IDC_BUTTON3, OnShow)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CAnt_testDlg message handlers

BOOL CAnt_testDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	ShowWindow(SW_MAXIMIZE);
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CAnt_testDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CAnt_testDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CAnt_testDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CAnt_testDlg::Onend() //退出
{
	// TODO: Add your control notification handler code here
	PostQuitMessage(0);	
	
	
}

void CAnt_testDlg::Onrun() //運(yùn)行
{
	// TODO: Add your control notification handler code here
	
	UpdateData(true);
	if(m_edit2<=0 || m_edit3<=0)
	{
		MessageBox("請正確輸入?yún)?shù)!",NULL,MB_OK);
	}
	else
	{
        srand(time(NULL));
		alpha=m_edit4;
		num_ants=m_edit2;
		num_iters=m_edit3;
		num_layers=m_edit11;
		dimension=m_edit8;
		p0=m_edit6;
		rho=m_edit5;
		tau0=m_edit7;		
		allocate_vars();		
		int cur_layer, cur_ant;
		init_vars();
		cur_iter=0;
		SetTimer(1,10, NULL);
	}
}

void CAnt_testDlg::release_vars()  //釋放
{
    int i,j;
	for (i=0; i<num_layers; i++)
	{
		for (j=0; j<10; j++)
			delete[] tau[i][j];
		delete[] tau[i];
	}
	delete[] tau;
	for (i=0; i<num_ants; i++)
		delete[] ant[i];
	delete[] ant;
	for (i=0; i<num_ants; i++)
		delete[] x[i];
	delete[] x;
	delete[] fit;
	delete[] y;
	delete[] gbant;
	delete[] ibant;
	need_release=false;
}
void CAnt_testDlg::allocate_vars()  //分配
{	
    int i,j;
	if(need_release==true)
		release_vars();	
	tau=new float**[num_layers];
	for (i=0; i<num_layers; i++)
	{
		tau[i]=new float*[10];
		for (j=0; j<10; j++)		
			tau[i][j]=new float[10 +1];	//the last element is used to store the accumulate value of the foregoing 10 numbers
	}
	ant=new int*[num_ants];
	for (i=0; i<num_ants; i++)
		ant[i]=new int[num_layers];

	//float *fit;
	fit=new float[num_ants];

	//float *y;
	y=new float[num_ants];

	//int *gbant;
	gbant=new int[num_layers];

	//int *ibant;
	ibant=new int[num_layers];

	//float **x;
	x=new float*[num_ants];
	for (i=0; i<num_ants; i++)
		x[i]=new float[dimension];
	need_release=true;
	layers_per_dimension=num_layers/dimension;
}
void CAnt_testDlg::init_vars()  //初始化
{
    int i, j, k;
	gbfit=100000;
	gby=0;
	for (i=0; i<num_layers; i++)
	{
		for (j=0; j<10; j++)
		{
			for (k=0; k<10; k++)
				//tau[i][j][k]=tau_max;
				tau[i][j][k]=tau0;
			//tau[i][j][10]=tau_max*10;		//sum of the foregoing ten tau
			tau[i][j][10]=tau0*10;
		}
	}
}

void CAnt_testDlg::ant_move(int ant_no, int layer)  //螞蟻移動
{
	int last_pos, next_pos;
	int i;
	float t;
	if(layer%8==0)
		last_pos=0;
	else
		last_pos=ant[ant_no][layer-1];
	t=(float)rand()/RAND_MAX;
	if ( t<p0 )

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二区三区老鸭窝 | 久久先锋影音av鲁色资源网| 亚洲国产精品99久久久久久久久| 亚洲国产一区二区a毛片| 韩国精品免费视频| 欧美一区二视频| 亚洲图片欧美综合| av成人老司机| 久久精品视频一区二区三区| 日本三级韩国三级欧美三级| 欧美综合久久久| 亚洲欧洲无码一区二区三区| 国产精品综合av一区二区国产馆| 91.com在线观看| 婷婷综合五月天| 欧美日韩在线一区二区| 亚洲综合一二三区| 91丨九色porny丨蝌蚪| 国产精品水嫩水嫩| 成人在线一区二区三区| 国产欧美日韩综合| 国产精品一线二线三线| 久久人人97超碰com| 久久66热re国产| 日韩精品一区二区三区视频播放 | 99视频精品在线| 亚洲国产精品成人久久综合一区| 久久99最新地址| 精品久久国产字幕高潮| 免费不卡在线观看| 日韩亚洲欧美成人一区| 日韩高清一区二区| 欧美一区在线视频| 麻豆精品一二三| 欧美电视剧在线看免费| 精品午夜一区二区三区在线观看 | 亚洲婷婷国产精品电影人久久| 久久se这里有精品| 精品国产区一区| 国产乱对白刺激视频不卡| 国产日韩精品一区二区浪潮av| 国产美女精品在线| 国产女人18毛片水真多成人如厕 | 久草在线在线精品观看| 精品少妇一区二区三区免费观看| 国内欧美视频一区二区| 中文字幕av不卡| 色狠狠桃花综合| 日韩中文字幕不卡| 精品剧情v国产在线观看在线| 国产综合久久久久影院| 国产精品福利影院| 欧美亚一区二区| 免费av成人在线| 日本一区二区三区国色天香 | 亚洲欧美成人一区二区三区| 欧美嫩在线观看| 国产盗摄精品一区二区三区在线 | 国产欧美日韩在线看| 91片黄在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 久久新电视剧免费观看| 91精彩视频在线| 久久精品免费看| 亚洲丝袜另类动漫二区| 日韩一区二区三区在线| 91丝袜呻吟高潮美腿白嫩在线观看| 偷拍一区二区三区四区| 国产欧美精品一区二区色综合| 欧美偷拍一区二区| 国产电影精品久久禁18| 亚洲成人av中文| 久久精品无码一区二区三区| 欧美亚洲自拍偷拍| 丁香婷婷综合五月| 美女视频网站久久| 亚洲综合一区二区| 国产精品久久久久久妇女6080| 欧美日韩电影一区| 99r国产精品| 国产精品系列在线播放| 日韩不卡一区二区三区| 亚洲男人的天堂网| 久久精品亚洲国产奇米99| 欧美高清你懂得| 色8久久人人97超碰香蕉987| 国产麻豆91精品| 老司机免费视频一区二区三区| 一区二区在线观看免费视频播放 | 亚洲综合成人网| 国产精品乱码一区二区三区软件 | 欧美日韩久久久一区| 白白色亚洲国产精品| 久久99精品一区二区三区 | 亚洲精品国产第一综合99久久| 久久久久久免费毛片精品| 日韩一级视频免费观看在线| 欧美性生活久久| 91丨porny丨在线| 99精品在线免费| 不卡的看片网站| 成人黄色电影在线| 国产成人在线视频网站| 国产一区视频网站| 国产一级精品在线| 国产在线视频精品一区| 精品综合久久久久久8888| 奇米在线7777在线精品| 日本不卡1234视频| 老司机精品视频一区二区三区| 免费欧美日韩国产三级电影| 天堂一区二区在线免费观看| 视频在线观看国产精品| 日韩av一区二| 久久精工是国产品牌吗| 国产在线麻豆精品观看| 国产一区欧美一区| 国产成人免费视频网站| av不卡在线观看| 91老司机福利 在线| 欧美日韩综合在线免费观看| 欧美性高清videossexo| 欧美高清dvd| 欧美大片日本大片免费观看| 精品国精品国产| 国产日产欧美精品一区二区三区| 国产精品天美传媒| 亚洲一区二区三区小说| 视频一区欧美日韩| 免费的成人av| 高清av一区二区| 在线观看国产一区二区| 日韩一区二区三区在线视频| www成人在线观看| 17c精品麻豆一区二区免费| 亚洲妇女屁股眼交7| 日本不卡免费在线视频| 国产成人精品亚洲777人妖| 色av成人天堂桃色av| 日韩一区二区电影网| 国产精品进线69影院| 亚洲一线二线三线久久久| 奇米四色…亚洲| 99久久99久久综合| 制服丝袜成人动漫| 国产精品无圣光一区二区| 亚洲h在线观看| 国产精品一区二区x88av| 91麻豆成人久久精品二区三区| 欧美精品久久一区| 欧美激情一区三区| 亚洲国产一区在线观看| 国产一区日韩二区欧美三区| 欧美亚洲高清一区| 久久免费的精品国产v∧| 亚洲一区二区三区在线| 国产另类ts人妖一区二区| 欧美三级电影一区| 日本一区二区动态图| 免费高清在线一区| 一本到高清视频免费精品| 精品少妇一区二区三区在线播放| 一区二区三区在线免费观看 | 91丨porny丨国产| 欧美第一区第二区| 亚洲一区在线电影| 99国产一区二区三精品乱码| 精品久久久久久久久久久久包黑料| 亚洲少妇屁股交4| 国产精品一区二区在线播放 | 欧美色视频在线| 综合av第一页| 国产一区二区三区日韩| 日韩一级免费一区| 亚洲综合色成人| 一本久久a久久精品亚洲| 国产日韩v精品一区二区| 美女视频黄免费的久久| 欧美少妇bbb| 亚洲男人的天堂网| 国产高清不卡二三区| 91精品国产综合久久久久久久久久 | 国产欧美一区二区三区沐欲| 麻豆精品精品国产自在97香蕉| 欧美日韩高清一区二区三区| 亚洲精品第1页| 91亚洲永久精品| 国产精品国产三级国产a| 成人夜色视频网站在线观看| 亚洲精品一区二区三区99| 极品美女销魂一区二区三区| 91精品国产福利| 男男gaygay亚洲| 日韩午夜在线播放| 老司机精品视频线观看86 | 欧美亚洲综合在线| 午夜精品在线视频一区| 欧美性三三影院| 日韩电影网1区2区| 日韩免费高清电影|