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

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

?? eightqueendlg.cpp

?? 動態演示八皇后的回溯
?? CPP
字號:
// EightQueenDlg.cpp : implementation file
//

#include "stdafx.h"
#include "EightQueen.h"
#include "EightQueenDlg.h"
#include "QueenPanel.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// 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)
	virtual BOOL OnInitDialog();
	//}}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)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CEightQueenDlg dialog

CEightQueenDlg::CEightQueenDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CEightQueenDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CEightQueenDlg)
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CEightQueenDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CEightQueenDlg)
	DDX_Control(pDX, IDC_QUEEN_PANEL, m_panel);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CEightQueenDlg, CDialog)
	//{{AFX_MSG_MAP(CEightQueenDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_START, OnStart)
	ON_BN_CLICKED(IDC_PAUSE, OnPause)
	ON_BN_CLICKED(IDC_CONTINUE, OnContinue)
	ON_WM_CLOSE()
	ON_BN_CLICKED(IDC_STEP_BY, OnStepBy)
	ON_BN_CLICKED(IDC_ABOUT, OnAbout)
	ON_BN_CLICKED(IDC_STOP, OnStop)
	ON_BN_CLICKED(IDC_NO_INT, OnNoInt)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CEightQueenDlg message handlers

BOOL CEightQueenDlg::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 her
	this_mutex = CreateMutex(NULL,FALSE,NULL);
	pause_event = CreateEvent( 
            NULL,     // no security attributes
            TRUE,    // manual-reset event
            FALSE,     // initial state is signaled
            NULL);  
	GetDlgItem(IDC_BOARD_SIZE)->SetWindowText("8");
	m_panel.SetSize(8);
	CButton *step = (CButton *)GetDlgItem(IDC_STEP_BY);
	m_step = (step->GetCheck()==BST_CHECKED)?TRUE:FALSE;
	CButton *no_int = (CButton *)GetDlgItem(IDC_NO_INT);
	m_no_int = (step->GetCheck()==BST_CHECKED)?TRUE:FALSE;
	canceling = running = FALSE;		
	UpdateUI();	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CEightQueenDlg::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 CEightQueenDlg::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 CEightQueenDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CEightQueenDlg::OnStart() 
{
	// TODO: Add your control notification handler code here
	DWORD dwThreadId; 
    HANDLE hThread;    
	
	CString str;
	GetDlgItem(IDC_BOARD_SIZE)->GetWindowText(str);
	int newn = atoi(str);
	if(newn<=0) {
		MessageBox("大小不能小于1", "警告", MB_OK);
		return;
	}
	else {
		n = newn;
	}
	m_panel.SetSize(n);
	step = m_step;
	no_int = m_no_int;
	running = TRUE;
	pausing = canceling = FALSE;
	UpdateUI();
    hThread = CreateThread( 
        NULL,                        // default security attributes 
        0,                           // use default stack size  
        ThreadGo,                  // thread function 
        this,                // argument to thread function 
        0,                           // use default creation flags 
        &dwThreadId);                // returns the thread identifier 
 
   // Check the return value for success. 
 
   if (hThread == NULL) 
   {     
      MessageBox( NULL, "CreateThread failed.", MB_OK );
   }
   
}

DWORD WINAPI CEightQueenDlg::ThreadGo( LPVOID lpParam ) 
{ 
	CEightQueenDlg *dlg = (CEightQueenDlg *)lpParam;	   
	dlg->Go();	
    return 0; 	
} 

void WINAPI CEightQueenDlg::Go() {    
    count = 0;
    queen = new int[n];
    rk = new BOOLEAN[2 * n - 1];
    lk = new BOOLEAN[2 * n - 1];
    mk = new BOOLEAN[n];
    for (int i = 0; i < n; i++) {
      queen[i] = -1;	  
    }    
	memset(rk, 0, (2*n-1)*sizeof(BOOLEAN));
	memset(lk, 0, (2*n-1)*sizeof(BOOLEAN));
	memset(mk, 0, n*sizeof(BOOLEAN));
	ResetEvent(pause_event);
    Step(0);
	delete [] queen;
	delete [] rk;
	delete [] lk;
	delete [] mk;
	if(!canceling) {
		TCHAR msg[30];
		sprintf(msg, "找到%d種組合。", count);
		MessageBox(msg, "八皇后", MB_OK);
	}
	count = 0;
	canceling = running = FALSE;
	UpdateUI();
  }

  /**
   * 安排皇后的遞歸算法:   
   */

void WINAPI CEightQueenDlg::Step(int i) {
    for (int j = 0; j < n; j++) {
		WaitForSingleObject(this_mutex, INFINITE);
		if(canceling) {
			return;
		}
		ReleaseMutex(this_mutex);
      if (!mk[j] && !rk[i + j]  && !lk[n - 1 + i - j] ) {
        queen[i] = j;
        rk[i + j] = TRUE;
        lk[n - 1 + i - j] = TRUE;
        mk[j] = TRUE;
        if (i == n - 1) {
          count++;          
          UpdateQPanel(i, queen[i]);		  
		  WaitForSingleObject(this_mutex,INFINITE);
		  if(!step&&!no_int) {
			  ReleaseMutex(this_mutex);
			  UpdateUI();
			  DoPause();			  
		  }
		  else {
			  ReleaseMutex(this_mutex);
		  }
          //System.exit(0);
        }
        else {
          UpdateQPanel(i, queen[i]);
          Step(i + 1);
        }
        queen[i] = -1;
        rk[i + j] = FALSE;
        lk[i + n - 1 - j] = FALSE;
        mk[j] = FALSE;
        UpdateQPanel(i, queen[i]);
      }
    }
  }

void CEightQueenDlg::OnPause() 
{
	// TODO: Add your control notification handler code here
	WaitForSingleObject(this_mutex,INFINITE);	
	step = TRUE;
	if(pausing) {
		SetEvent(pause_event); 
	}
	ReleaseMutex(this_mutex);    	
	UpdateUI();
}

void CEightQueenDlg::OnContinue() 
{
	// TODO: Add your control notification handler code here
	WaitForSingleObject(this_mutex,INFINITE);
	step = FALSE;	
	if(pausing) {
		SetEvent(pause_event); 
	}
	ReleaseMutex(this_mutex);	
	UpdateUI();
}

void CEightQueenDlg::OnClose() 
{
	// TODO: Add your message handler code here and/or call default
	if(running) {
		this->MessageBox("正在運行,請先按“停止”按鈕停止。", "警告");
	} else
		CDialog::EndDialog(0);
}

void CEightQueenDlg::OnStepBy() 
{
	// TODO: Add your control notification handler code here
	CButton *step = (CButton *)GetDlgItem(IDC_STEP_BY);
	m_step = (step->GetCheck()==BST_CHECKED)?TRUE:FALSE;
	if(m_step) {
		CButton *autoBtn = (CButton *)GetDlgItem(IDC_NO_INT);
		autoBtn->SetCheck(FALSE);
		m_no_int = FALSE;
	}
}

void CEightQueenDlg::UpdateUI()
{
	WaitForSingleObject(this_mutex, INFINITE);
	GetDlgItem(IDC_BOARD_SIZE)->EnableWindow(!running&&!canceling);
	GetDlgItem(IDC_NO_INT)->EnableWindow(!running&&!canceling);
	GetDlgItem(IDC_STEP_BY)->EnableWindow(!running&&!canceling);
	GetDlgItem(IDC_START)->EnableWindow(!running&&!canceling);

	GetDlgItem(IDC_PAUSE)->EnableWindow(running&&!canceling);
	GetDlgItem(IDC_CONTINUE)->EnableWindow(running&&!canceling&&pausing);
	GetDlgItem(IDC_STOP)->EnableWindow(running&&!canceling);	
	ReleaseMutex(this_mutex);
}

void CEightQueenDlg::OnAbout() 
{
	// TODO: Add your control notification handler code here	
	CAboutDlg dlgAbout;
	dlgAbout.DoModal();	
}

void CEightQueenDlg::UpdateQPanel(int *queen) {
	m_panel.SetQueen(queen);
	WaitForSingleObject(this_mutex, INFINITE);
	if(step) {
		ReleaseMutex(this_mutex);
		DoPause();
	} 
	else {
		ReleaseMutex(this_mutex);
	}
}

void CEightQueenDlg::UpdateQPanel(int row, int col) {
	m_panel.SetQueen(row, col);
	if(step) {
		ReleaseMutex(this_mutex);		
		DoPause();
	} 
	else {
		ReleaseMutex(this_mutex);
	}
}

void CEightQueenDlg::DoPause() {
	WaitForSingleObject(this_mutex, INFINITE);
	pausing = TRUE;
	ReleaseMutex(this_mutex);
	UpdateUI();
	WaitForSingleObject(pause_event,INFINITE);
	ResetEvent(pause_event);
	WaitForSingleObject(this_mutex, INFINITE);
	pausing  = FALSE;
	ReleaseMutex(this_mutex);
	UpdateUI();
}

void CEightQueenDlg::OnStop() 
{
	// TODO: Add your control notification handler code here
	WaitForSingleObject(this_mutex, INFINITE);
	step = FALSE;
	canceling = TRUE;	
	if(pausing) {
		SetEvent(pause_event); 
	}
	ReleaseMutex(this_mutex);	
	UpdateUI();
}


void CEightQueenDlg::OnNoInt() 
{
	// TODO: Add your control notification handler code here
	CButton *autoBtn = (CButton *)GetDlgItem(IDC_NO_INT);
	m_no_int = (autoBtn->GetCheck()==BST_CHECKED)?TRUE:FALSE;
	if(m_no_int) {
		CButton *step = (CButton *)GetDlgItem(IDC_STEP_BY);
		step->SetCheck(FALSE);
		m_step = FALSE;
	}
}

BOOL CAboutDlg::OnInitDialog() 
{
	CDialog::OnInitDialog();
	
	// TODO: Add extra initialization here
	GetDlgItem(IDC_COPY_RIGHT)->SetWindowText("版權所有 Yuan Yq( yyqkkk@126.com )");	
	return TRUE;  // return TRUE unless you set the focus to a control
	              // EXCEPTION: OCX Property Pages should return FALSE
}

void CEightQueenDlg::OnOK ()
{
}
void CEightQueenDlg::OnCancel()
{
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区影院| 欧美日韩一区二区电影| 在线视频观看一区| 午夜久久久久久久久久一区二区| 欧美另类高清zo欧美| 日精品一区二区| 国产调教视频一区| 欧美性受xxxx| 国内精品写真在线观看| 亚洲特黄一级片| 欧美日韩一区二区在线视频| 成人免费看片app下载| 亚洲国产日产av| 久久久久88色偷偷免费| 欧美日韩电影在线播放| 日本亚洲天堂网| 日韩理论片中文av| 精品久久人人做人人爽| 91久久精品一区二区三区| 麻豆国产一区二区| 亚洲自拍与偷拍| 久久久久综合网| 欧美一区二区三区四区久久| 成人高清伦理免费影院在线观看| 三级不卡在线观看| 亚洲日本va午夜在线影院| 欧美一卡在线观看| 欧美性生交片4| 不卡一区二区在线| 蜜桃av噜噜一区二区三区小说| 国产精品福利电影一区二区三区四区| 欧美妇女性影城| 一道本成人在线| 不卡的av网站| 成人成人成人在线视频| 久久99精品久久久久久久久久久久| 亚洲三级电影网站| 中文字幕乱码日本亚洲一区二区| 欧美一级国产精品| 欧美日韩情趣电影| 在线观看亚洲专区| 色综合天天狠狠| 成人午夜av影视| 国产精品综合视频| 国产精品2024| 狠狠色综合日日| 奇米在线7777在线精品| 亚洲成a人v欧美综合天堂| 亚洲精品免费在线播放| 久久精品这里都是精品| 日韩美女在线视频| 日韩欧美你懂的| 欧美一区二区三区四区久久| 色哟哟在线观看一区二区三区| 色狠狠色噜噜噜综合网| 欧美中文字幕亚洲一区二区va在线| caoporm超碰国产精品| 不卡在线观看av| 粗大黑人巨茎大战欧美成人| 国产999精品久久久久久绿帽| 国产一区二区三区在线看麻豆| 精品亚洲porn| 国产成人精品综合在线观看| 韩国视频一区二区| 国产乱人伦偷精品视频不卡| 免费成人深夜小野草| 国产麻豆精品一区二区| 国产一区在线精品| 风间由美一区二区av101| 国产69精品久久99不卡| 国产高清不卡一区二区| 成人免费视频caoporn| 99久久免费视频.com| 99re8在线精品视频免费播放| 91香蕉视频污在线| 欧美色网一区二区| 日韩美一区二区三区| 国产欧美日韩综合精品一区二区 | 成人性色生活片免费看爆迷你毛片| 精品写真视频在线观看| 国产69精品一区二区亚洲孕妇| 在线一区二区观看| 日韩一区二区精品| 亚洲欧美另类综合偷拍| 日本不卡视频一二三区| 东方欧美亚洲色图在线| 欧美日韩精品久久久| 国产亚洲精品久| 亚洲夂夂婷婷色拍ww47| 国产91精品久久久久久久网曝门 | 欧美三电影在线| 久久男人中文字幕资源站| 亚洲一区二区三区中文字幕在线| 久久99日本精品| 日本韩国欧美在线| 久久精品夜色噜噜亚洲aⅴ| 一区二区三区欧美久久| 国模一区二区三区白浆| 欧美在线免费观看亚洲| 国产午夜精品一区二区| 日韩精品亚洲一区| 99精品偷自拍| 久久久久一区二区三区四区| 日韩精品色哟哟| 欧美综合色免费| 欧美国产欧美综合| 捆绑调教美女网站视频一区| 欧美主播一区二区三区| 国产精品不卡一区二区三区| 精品午夜一区二区三区在线观看 | 337p粉嫩大胆色噜噜噜噜亚洲| 一区二区三区高清| 粉嫩嫩av羞羞动漫久久久| 91麻豆精品国产91久久久使用方法 | 精品国产一区二区亚洲人成毛片 | 国产伦精品一区二区三区视频青涩| 欧美综合色免费| 亚洲人成亚洲人成在线观看图片 | 成人午夜av电影| 欧美一级日韩免费不卡| 日韩精品一区二区在线观看| 精品综合久久久久久8888| 欧美色图天堂网| 一级特黄大欧美久久久| 91在线视频观看| 亚洲日本在线a| 欧美在线小视频| 国产综合久久久久影院| 婷婷久久综合九色综合伊人色| 国产成人午夜精品5599| 欧美亚洲一区二区在线观看| 欧美一级久久久| 欧美一区二区三区思思人| 欧美亚洲尤物久久| 国产 欧美在线| 一卡二卡欧美日韩| 678五月天丁香亚洲综合网| 日本欧美久久久久免费播放网| 欧美精品一区二区三区一线天视频| 国产精品一区二区免费不卡 | 九九精品视频在线看| 日韩精品一区二区三区在线播放| 奇米在线7777在线精品 | 精品夜夜嗨av一区二区三区| 国产无人区一区二区三区| 成人伦理片在线| 亚洲成人免费影院| 久久蜜桃av一区二区天堂| 欧美主播一区二区三区| 国产精品综合久久| 日韩精品一二三| 亚洲狠狠丁香婷婷综合久久久| 欧美成人a∨高清免费观看| 粉嫩av一区二区三区| 久久精品国产一区二区三 | 欧美日韩久久一区| 久久亚洲一区二区三区四区| 欧美国产精品一区二区三区| 日本一区二区三区久久久久久久久不| 中文字幕国产一区二区| 亚洲视频每日更新| 亚洲va在线va天堂| 国内精品免费**视频| 欧美欧美午夜aⅴ在线观看| 成人性生交大片免费看中文 | 日韩视频免费直播| 亚洲伦理在线精品| 99re热这里只有精品免费视频| 欧美一二三四区在线| 日产国产欧美视频一区精品| 51午夜精品国产| 国产一区二区日韩精品| 国产精品久久久久久福利一牛影视| 91麻豆福利精品推荐| 男女视频一区二区| 亚洲欧美综合在线精品| 欧美日韩小视频| 国产a久久麻豆| 亚洲bt欧美bt精品| 久久精品免费在线观看| 色婷婷精品久久二区二区蜜臀av| 亚洲va欧美va人人爽午夜| 久久国产人妖系列| 国产一区二区三区电影在线观看 | 日韩免费视频一区二区| 欧洲视频一区二区| 欧美午夜电影一区| 亚洲夂夂婷婷色拍ww47 | 亚洲天堂成人在线观看| 欧美日本在线播放| av亚洲精华国产精华| 日韩av电影免费观看高清完整版| 欧美日韩一区二区三区在线| 亚洲午夜久久久| 欧美精品一二三四| 波多野结衣的一区二区三区| 日韩高清一级片| 亚洲四区在线观看| 欧美草草影院在线视频| 一本一本大道香蕉久在线精品|