C++ 實例之九宮格廣度優(yōu)先遍歷
C++ 實例之九宮格廣度優(yōu)先遍歷
基本思路:
廣度優(yōu)先遍歷,每次找到1的位置,分別向上、向下、向左、向右移動。把移動后的每個狀態(tài)存儲到隊列中,彈出隊頭,判斷是否為最終結(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;//隊列中數(shù)量 int flag=0;//是否尋找到標記 int ans=0;//最小步數(shù),也是擴展的層數(shù) int head=0;//因為不是鏈表,用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),進行擴展 { for(int row=0;row<3;row++) for(int col=0;col<3;col++) { if(cur.number[row][col]==1) //找到1,進行擴展 { //將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)無解,即不可能到達最終結(jié)果狀態(tài)??
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
C語言進階輸入輸出重定向與fopen函數(shù)使用示例詳解
這篇文章主要為大家介紹了C語言進階輸入輸出重定向與fopen函數(shù)的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-02-02C語言超詳細講解數(shù)據(jù)結(jié)構(gòu)中的線性表
線性表,數(shù)據(jù)結(jié)構(gòu)中最簡單的一種存儲結(jié)構(gòu),專門用于存儲邏輯關(guān)系為"一對一"的數(shù)據(jù)。線性表是基于數(shù)據(jù)在實際物理空間中的存儲狀態(tài),又可細分為順序表(順序存儲結(jié)構(gòu))和鏈表2022-05-05C語言鏈表實現(xiàn)通訊錄系統(tǒng)課程設(shè)計
這篇文章主要為大家詳細介紹了C語言鏈表實現(xiàn)通訊錄系統(tǒng)課程設(shè)計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06VC中實現(xiàn)GB2312、BIG5、Unicode編碼轉(zhuǎn)換的方法
這篇文章主要介紹了VC中實現(xiàn)GB2312、BIG5、Unicode編碼轉(zhuǎn)換的方法,該功能非常實用,需要的朋友可以參考下2014-07-07