C++ 實例之九宮格廣度優(yōu)先遍歷
更新時間:2017年05月09日 08:47:30 投稿:lqh
這篇文章主要介紹了C++ 實例之九宮格廣度優(yōu)先遍歷的相關(guān)資料,需要的朋友可以參考下
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)文章
聊聊Qt+OpenCV聯(lián)合開發(fā)之圖像的創(chuàng)建與賦值問題
這篇文章主要介紹了Qt+OpenCV聯(lián)合開發(fā)之圖像的創(chuàng)建與賦值問題,給大家介紹了圖像的克隆及拷貝問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-01-01

