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

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

?? riverdlg.cpp

?? 過河算法屬于面試經典算法
?? CPP
字號:
// RiverDlg.cpp : implementation file
//

#include "stdafx.h"
#include "River.h"
#include "RiverDlg.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)
	//}}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()

/////////////////////////////////////////////////////////////////////////////
// CRiverDlg dialog

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

void CRiverDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CRiverDlg)
	DDX_Control(pDX, IDC_MOVESTEP, m_ListStep);
	DDX_Control(pDX, IDC_MYROAD, m_ListMyRoad);
	DDX_Control(pDX, IDC_ROOT, m_ListRoot);
	DDX_Text(pDX, IDC_GOEND, m_nGoEnd);
	DDX_Text(pDX, IDC_GOBEGIN, m_nGoBegin);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CRiverDlg, CDialog)
	//{{AFX_MSG_MAP(CRiverDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_RIVER, OnRiver)
	ON_BN_CLICKED(IDC_PARSE, OnParse)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CRiverDlg message handlers

BOOL CRiverDlg::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
	m_bEndFlag = FALSE;
	m_ListRoot.InsertColumn(0,"第幾個節點", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(1,"父親位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(2,"母親位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(3,"女兒1位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(4,"女兒2位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(5,"兒子1位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(6,"兒子2位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(7,"警察位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(8,"歹徒位置", LVCFMT_LEFT,60);
	m_ListRoot.InsertColumn(9,"船的位置", LVCFMT_LEFT,60);

	m_ListMyRoad.InsertColumn(0,"第幾條路", LVCFMT_LEFT,60);
	m_ListMyRoad.InsertColumn(1,"如何走", LVCFMT_LEFT,60);

	m_ListStep.InsertColumn(0,"步驟", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(1,"父親位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(2,"母親位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(3,"女兒1位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(4,"女兒2位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(5,"兒子1位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(6,"兒子2位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(7,"警察位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(8,"歹徒位置", LVCFMT_LEFT,60);
	m_ListStep.InsertColumn(9,"船的位置", LVCFMT_LEFT,60);


	///////////////////////////////////////////////////////
	DWORD dwStyleEx;
	//LVS_SINGLESEL
	dwStyleEx = LVS_EX_FULLROWSELECT | LVS_REPORT |  LVS_EX_ONECLICKACTIVATE; 
	m_ListMyRoad.SetExtendedStyle( dwStyleEx );
	m_ListRoot.SetExtendedStyle( dwStyleEx );
	m_ListStep.SetExtendedStyle( dwStyleEx );
	

	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

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

void CRiverDlg::OnRiver() 
{
	// TODO: Add your control notification handler code here
	UpdateData();
	if(m_nGoEnd > m_wheres.GetSize()-1)
	{
		MessageBox("填入數字錯誤,這種情況不存在");
		return;
	}

	m_bEndFlag = FALSE;			//重置結束標志
	m_ListStep.DeleteAllItems();
	m_ListStep.SetRedraw(FALSE);
	
	int i(0);
	int nItem(0);
	CString strInfo;

	//聲明結點訪問標志
	BOOL *Visited = new BOOL[m_wheres.GetSize()];
	for(i = 0 ; i<m_wheres.GetSize(); i++)
		Visited[i] = FALSE;
	//初始化道路
	
	CArray<int, int> Road;

	//遍歷找到結點
	GoRiver(Road, m_nGoBegin, m_nGoEnd, m_MoveAll, Visited);
	CString saMessage[3] = {"左岸","船上","右岸"};
	nItem = 0;
	for(i = 0; i<Road.GetSize(); i++)
	{
		strInfo.Format("第%d步", i+1);
		nItem = m_ListStep.InsertItem(nItem, strInfo);
		m_ListStep.SetItemText(nItem, 0, strInfo);
		m_ListStep.SetItemText(nItem, 1, saMessage[m_wheres.GetAt(Road.GetAt(i)).father-1]);
		m_ListStep.SetItemText(nItem, 2, saMessage[m_wheres.GetAt(Road.GetAt(i)).mother-1]);
		m_ListStep.SetItemText(nItem, 3, saMessage[m_wheres.GetAt(Road.GetAt(i)).daughter1-1]);
		m_ListStep.SetItemText(nItem, 4, saMessage[m_wheres.GetAt(Road.GetAt(i)).daughter2-1]);
		m_ListStep.SetItemText(nItem, 5, saMessage[m_wheres.GetAt(Road.GetAt(i)).son1-1]);
		m_ListStep.SetItemText(nItem, 6, saMessage[m_wheres.GetAt(Road.GetAt(i)).son2-1]);
		m_ListStep.SetItemText(nItem, 7, saMessage[m_wheres.GetAt(Road.GetAt(i)).plice-1]);
		m_ListStep.SetItemText(nItem, 8, saMessage[m_wheres.GetAt(Road.GetAt(i)).shife-1]);
		m_ListStep.SetItemText(nItem, 9, saMessage[m_wheres.GetAt(Road.GetAt(i)).boat-1]);
		nItem++;
	}

	delete[] Visited;
	m_ListStep.SetRedraw(TRUE);
	m_ListStep.Invalidate();
	
}

void CRiverDlg::GoRiver(CArray<int,int>& p_Road, int Begin, int End, CArray<Move, Move>& p_MoveAll, BOOL *Visited)
{
	//深度遍歷圖形算法
	//此步不需要因為從設置了結束位以后就再也沒調用GORIVER了
	//if(m_bEndFlag) return;
	int i;
	Visited[Begin] = TRUE;
	//講其加入到走過的路中
	p_Road.Add(Begin);
	if(Begin == End)
	{
		m_bEndFlag = TRUE;
		MessageBox("找到了從起點通往終點道路");
		return;
	}
	
	for(i=0; i<p_MoveAll.GetSize(); i++)
	{
		if(p_MoveAll.GetAt(i).m_nNow == Begin)
		{
			if(Visited[p_MoveAll.GetAt(i).m_nNext] == FALSE)
			{
				GoRiver(p_Road, p_MoveAll.GetAt(i).m_nNext, End, p_MoveAll, Visited);
				if(m_bEndFlag) return;
			}
		}
	}

	//如果遍歷完了還沒找到說明此路不通出棧
	p_Road.RemoveAt(p_Road.GetSize()-1);

	

}

void CRiverDlg::OnParse() 
{
	//找的所有的狀態結點位置及所有可以走過的路
	// TODO: Add your control notification handler code here
	CString strInfo;//信息提示
	m_ListRoot.DeleteAllItems();//ROOT清空
	m_ListMyRoad.DeleteAllItems();//MYROAD清空
	m_wheres.RemoveAll();  //結點清空
	
	InWhere where;			//臨時結點
	m_ListRoot.SetRedraw(FALSE); //不許重繪圖
	int AccordNum(0); //序號
	int nItem(0);
	int i,j,k,l,m,n,o,p,q;
	for(i=1; i<4; i++)
		for(j=1; j<4; j++)
			for(k=1; k<4; k++)
				for(l=1; l<4; l++)
					for(m=1; m<4; m++)
						for(n=1; n<4; n++)
							for(o=1; o<4; o++)
								for(p=1; p<4; p++)
									for(q = 1; q<4; q++)
									{
										where.daughter1 = i;
										where.daughter2 = j;
										where.father = k;
										where.mother = l;
										where.plice = m;
										where.shife = n;
										where.son1 = o;
										where.son2 = p;
										where.boat = q;

										if(where.Test())
										{
											strInfo.Format("%d", AccordNum);
											nItem = m_ListRoot.InsertItem(nItem, strInfo);
											m_ListRoot.SetItemText(nItem,0,strInfo);
											strInfo.Format("%d", k);
											m_ListRoot.SetItemText(nItem,1,strInfo);
											strInfo.Format("%d", l);
											m_ListRoot.SetItemText(nItem,2,strInfo);
											strInfo.Format("%d", i);
											m_ListRoot.SetItemText(nItem,3,strInfo);
											strInfo.Format("%d", j);
											m_ListRoot.SetItemText(nItem,4,strInfo);
											strInfo.Format("%d", o);
											m_ListRoot.SetItemText(nItem,5,strInfo);
											strInfo.Format("%d", p);
											m_ListRoot.SetItemText(nItem,6,strInfo);
											strInfo.Format("%d", m);
											m_ListRoot.SetItemText(nItem,7,strInfo);
											strInfo.Format("%d", n);
											m_ListRoot.SetItemText(nItem,8,strInfo);
											strInfo.Format("%d", q);
											m_ListRoot.SetItemText(nItem,9,strInfo);

											m_wheres.Add(where);
											++AccordNum;
											++nItem;
										}
									}
		m_ListRoot.SetRedraw(TRUE);
		m_ListRoot.Invalidate();
		m_ListMyRoad.SetRedraw(FALSE);

		strInfo.Format("一共有%d種可能狀況", m_wheres.GetSize());
		MessageBox(strInfo);

		m_MoveAll.RemoveAll();
		Move mov;
		AccordNum = 0;
		nItem = 0;
		for(i = 0; i< m_wheres.GetSize(); i++)
			for(j = 0; j< m_wheres.GetSize(); j++)
			{
				mov.m_nNow = i;
				mov.m_nNext = j;
				if(i != j && mov.Test(m_wheres))
				{
					strInfo.Format("%d", AccordNum);
					nItem = m_ListMyRoad.InsertItem(nItem, strInfo);
					m_ListMyRoad.SetItemText(nItem,0,strInfo);
					strInfo.Format("%d->%d", i,j);
					m_ListMyRoad.SetItemText(nItem,1,strInfo);
					m_MoveAll.Add(mov);
					++AccordNum;
					++nItem;
				}
			}
			m_ListMyRoad.SetRedraw(TRUE);
			m_ListMyRoad.Invalidate();

		strInfo.Format("一共有%d種可能移動狀況", m_MoveAll.GetSize());
		MessageBox(strInfo);
		GetDlgItem(IDC_RIVER)->EnableWindow();
		GetDlgItem(IDC_GOEND)->EnableWindow();
		GetDlgItem(IDC_GOBEGIN)->EnableWindow();
		//設默認值為起點0終點最后m_wheres的最后個
		//設置默認的起點和終點
		m_nGoBegin = 0;
		m_nGoEnd = m_wheres.GetSize()-1;
		UpdateData(FALSE);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区三区电影| 麻豆成人久久精品二区三区小说| 精品美女一区二区三区| 欧美日本国产视频| 在线播放中文一区| 精品国产成人系列| 久久久亚洲精华液精华液精华液| 久久久91精品国产一区二区精品 | 视频一区视频二区中文| 亚洲成人一区在线| 丝袜亚洲精品中文字幕一区| 日本一道高清亚洲日美韩| 激情综合色综合久久综合| 国产伦精品一区二区三区视频青涩| 国产成人综合在线播放| av综合在线播放| 欧美巨大另类极品videosbest | 欧美一级生活片| 国产日韩亚洲欧美综合| 1024国产精品| 天天综合日日夜夜精品| 精品亚洲porn| 91免费观看在线| 欧美日本精品一区二区三区| 精品国产乱码久久久久久蜜臀| 日本一区二区三区四区在线视频 | 亚洲最新视频在线播放| 日韩激情中文字幕| 成人av在线观| 欧美亚州韩日在线看免费版国语版| 日韩一区二区视频在线观看| 久久久久久久av麻豆果冻| 一级中文字幕一区二区| 韩国中文字幕2020精品| 欧洲视频一区二区| 久久午夜色播影院免费高清| 亚洲综合在线视频| 国产伦精品一区二区三区视频青涩 | 樱花草国产18久久久久| 国产一区二区三区视频在线播放| 欧美三级电影精品| 国产精品丝袜一区| 美女一区二区在线观看| 色婷婷狠狠综合| 国产欧美日韩在线| 免费的国产精品| 欧美性生活大片视频| 国产欧美日韩亚州综合 | 亚洲欧洲制服丝袜| 国产美女娇喘av呻吟久久| 欧美日韩国产高清一区二区| 国产精品免费人成网站| 国产美女久久久久| 日韩视频在线永久播放| 五月天中文字幕一区二区| av男人天堂一区| 中文成人综合网| 韩国成人精品a∨在线观看| 欧美精品久久一区| 亚洲gay无套男同| 91丨porny丨在线| 国产精品成人免费精品自在线观看| 麻豆一区二区在线| 欧美一区二区三区人| 亚洲成人精品一区二区| 日本国产一区二区| 一区二区国产盗摄色噜噜| 91同城在线观看| 亚洲欧美日韩小说| 91碰在线视频| 亚洲蜜臀av乱码久久精品蜜桃| 成人a级免费电影| 亚洲桃色在线一区| 一本久久综合亚洲鲁鲁五月天| 日韩一区在线看| 91片在线免费观看| 亚洲一区二区偷拍精品| 欧美日韩成人一区二区| 无码av免费一区二区三区试看 | 视频在线观看一区| 欧美日韩久久久一区| 性做久久久久久免费观看欧美| 欧美色区777第一页| 亚洲超碰精品一区二区| 日韩精品一区二区在线观看| 日本亚洲一区二区| 久久天堂av综合合色蜜桃网| 国产不卡视频一区二区三区| 亚洲国产精品成人综合色在线婷婷 | 91理论电影在线观看| 亚洲国产欧美日韩另类综合 | 亚洲男同1069视频| 欧美又粗又大又爽| 秋霞成人午夜伦在线观看| 精品噜噜噜噜久久久久久久久试看| 激情文学综合插| 国产精品人人做人人爽人人添| 91欧美一区二区| 日韩精品每日更新| 久久精品夜夜夜夜久久| 色综合久久中文字幕| 免费人成网站在线观看欧美高清| 精品国产露脸精彩对白| 91麻豆免费看| 国产真实乱对白精彩久久| 中文字幕一区二区三区精华液 | 国产精品99久久久久久久vr | 麻豆极品一区二区三区| 综合久久一区二区三区| 日韩欧美国产一区二区在线播放| 成人免费三级在线| 日韩制服丝袜先锋影音| 中文字幕不卡在线观看| 欧美性受xxxx黑人xyx性爽| 日韩成人一区二区三区在线观看| 国产调教视频一区| 91超碰这里只有精品国产| 国产精品一区二区无线| 亚洲国产va精品久久久不卡综合| 日韩欧美国产综合在线一区二区三区| 成人黄色777网| 免费看日韩a级影片| 亚洲综合网站在线观看| 日韩美女在线视频| 欧美视频在线一区| 不卡的看片网站| 国产999精品久久久久久| 视频一区视频二区中文字幕| 亚洲欧美福利一区二区| 国产欧美精品一区| 日韩精品一区二区三区四区| 精品视频一区二区不卡| 91丨porny丨在线| 国产成人午夜高潮毛片| 日韩高清不卡一区| 亚洲国产日韩a在线播放性色| 亚洲欧洲精品一区二区三区不卡| 久久伊人中文字幕| 精品成人免费观看| 欧美xfplay| 5566中文字幕一区二区电影| 欧美日韩一区二区在线观看视频| 91小视频免费看| 99精品1区2区| 91麻豆免费观看| 色综合天天综合| 在线精品视频一区二区三四| 91亚洲精品乱码久久久久久蜜桃 | 视频一区中文字幕| 日日摸夜夜添夜夜添精品视频| 亚洲综合图片区| 亚洲成人久久影院| 日本亚洲电影天堂| 日本成人中文字幕| 亚洲一区二区视频| 亚洲福中文字幕伊人影院| 亚洲gay无套男同| 青青草精品视频| 国产精品性做久久久久久| 国产成人亚洲精品青草天美| 国产老肥熟一区二区三区| 成人理论电影网| 欧日韩精品视频| 91精品国产福利在线观看| 欧美成人r级一区二区三区| 久久综合色天天久久综合图片| 欧美高清在线一区二区| 亚洲精品中文在线| 视频一区二区三区入口| 蜜臀av亚洲一区中文字幕| 国产九色精品成人porny| 成人激情综合网站| 精品视频免费在线| 久久亚洲私人国产精品va媚药| 国产亚洲视频系列| 一区二区三区四区精品在线视频| 三级欧美韩日大片在线看| 国产在线国偷精品免费看| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美天天综合网| 久久综合中文字幕| 一区二区在线观看免费 | 国产人成一区二区三区影院| 一区二区三区中文字幕精品精品| 图片区日韩欧美亚洲| 成人影视亚洲图片在线| 欧美精品亚洲二区| 国产精品久久久久影院老司 | 91丨porny丨户外露出| 欧美久久一二区| 亚洲国产成人在线| 日韩中文字幕区一区有砖一区| 成人高清av在线| 日韩一级黄色大片| 一区二区三区精品久久久| 国产一区二区在线观看视频| 欧美最猛性xxxxx直播| 国产日韩av一区| 美洲天堂一区二卡三卡四卡视频| 91啪亚洲精品|