栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++ 实例之九宫格广度优先遍历

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++ 实例之九宫格广度优先遍历

C++ 实例之九宫格广度优先遍历

基本思路:

广度优先遍历,每次找到1的位置,分别向上、向下、向左、向右移动。把移动后的每个状态存储到队列中,弹出队头,判断是否为最终结果状态,如果是,输出遍历的层数(即移动步数),如果不是,把现阶段状态继续执行找到1向上向下向左向右移动操作。

#include 
 
typedef struct MyType 
{ 
  int number[3][3];int level; 
}MyType; 
 
MyType queue[10000]; 
 
MyType GetHead(int n) 
{ 
  return queue[n]; 
} 
 
//是否为最终结果状态 
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;//队列中数量 
  int flag=0;//是否寻找到标记 
  int ans=0;//最小步数,也是扩展的层数 
  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++); 
    //判断是否为最终状态 
    flag=IsFind(cur); 
    if(flag==1) 
    { 
      printf("最小步数为:%dn",cur.level); 
      break; 
    } 
    else   //不为最终状态,进行扩展 
    { 
      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; 
} 



有个问题,就是还没弄懂,怎么判断给定初始状态无解,即不可能到达最终结果状态??

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/63723.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号