C++ 實(shí)例之九宮格廣度優(yōu)先遍歷
C++ 實(shí)例之九宮格廣度優(yōu)先遍歷
基本思路:
廣度優(yōu)先遍歷,每次找到1的位置,分別向上、向下、向左、向右移動。把移動后的每個狀態(tài)存儲到隊(duì)列中,彈出隊(duì)頭,判斷是否為最終結(jié)果狀態(tài),如果是,輸出遍歷的層數(shù)(即移動步數(shù)),如果不是,把現(xiàn)階段狀態(tài)繼續(xù)執(zhí)行找到1向上向下向左向右移動操作。
#include<stdio.h> typedef struct MyType { int number[3][3];int level; }MyType; MyType queue[10000]; MyType GetHead(int n) { return queue[n]; } //是否為最終結(jié)果狀態(tài) int IsFind(MyType cur) { int flag=1; for(int i=0;i<3;i++) for(int j=0;j<3;j++) { if(cur.number[i][j]!=3*i+j+1) { flag=0; break; } } return flag; } int main() { int cnt=0;//隊(duì)列中數(shù)量 int flag=0;//是否尋找到標(biāo)記 int ans=0;//最小步數(shù),也是擴(kuò)展的層數(shù) int head=0;//因?yàn)椴皇擎湵?,用head來表示第一個 for(int m=0;m<3;m++) { for(int n=0;n<3;n++) { scanf("%d",&queue[cnt].number[m][n]); } } queue[cnt].level=0; cnt++; while(cnt!=0) { //出站 MyType cur=GetHead(head++); //判斷是否為最終狀態(tài) flag=IsFind(cur); if(flag==1) { printf("最小步數(shù)為:%d\n",cur.level); break; } else //不為最終狀態(tài),進(jìn)行擴(kuò)展 { for(int row=0;row<3;row++) for(int col=0;col<3;col++) { if(cur.number[row][col]==1) //找到1,進(jìn)行擴(kuò)展 { //將1向上移 if(row!=0) { MyType temp=cur; temp.number[row][col]=temp.number[row-1][col]; temp.number[row-1][col]=1; temp.level=cur.level+1; queue[cnt++]=temp; } //將1向右移動 if(col!=2) { MyType temp=cur; temp.number[row][col]=temp.number[row][col+1]; temp.number[row][col+1]=1; temp.level=cur.level+1; queue[cnt++]=temp; } //將1向下移動 if(row!=2) { MyType temp=cur; temp.number[row][col]=temp.number[row+1][col]; temp.number[row+1][col]=1; temp.level=cur.level+1; queue[cnt++]=temp; } //將1向左移動 if(col!=0) { MyType temp=cur; temp.number[row][col]=temp.number[row][col-1]; temp.number[row][col-1]=1; temp.level=cur.level+1; queue[cnt++]=temp; } } } } } return 0; }
有個問題,就是還沒弄懂,怎么判斷給定初始狀態(tài)無解,即不可能到達(dá)最終結(jié)果狀態(tài)??
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
上一篇:用C語言模仿Python函數(shù)的一種簡單實(shí)現(xiàn)方法
欄 目:C語言
本文標(biāo)題:C++ 實(shí)例之九宮格廣度優(yōu)先遍歷
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1595.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
- 01-10APUE筆記之:進(jìn)程環(huán)境詳解
- 01-10c++中inline的用法分析
- 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
- 01-10深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲方式詳解


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁面的局部加載