第8章 广度优先搜索.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第8章 广度优先搜索

第八章 广度优先搜索 广度优先搜索的过程 广度优先搜索算法描述: 广度优先搜索注意事项: 【参考程序】 #includeiostream #includecstring using namespace std; int ju[9][9]={{0,0,0,0,0,0,0,0,0}, {0,1,0,0,0,1,0,1,1}, {0,0,1,1,1,1,0,1,1}, {0,0,1,1,0,0,1,1,1}, {0,0,1,0,1,1,1,0,1}, {0,1,1,0,1,1,1,0,0}, {0,0,0,1,1,1,1,1,0}, {0,1,1,1,0,0,1,1,0}, {0,1,1,1,1,0,0,0,1}}; int a[101],b[101]; bool s[9]; //初始化 int out(int d) //输出过程 { coutchar(a[d]+64); while (b[d]) { d=b[d]; cout--char(a[d]+64); } coutendl; } void doit() { int head,tail,i; head=0;tail=1; //队首为0、队尾为1 a[1]=1; //记录经过的城市 b[1]=0; //记录前趋城市 s[1]=1; //表示该城市已经到过 do //步骤2 { head++; //队首加一,出队 for (i=1;i=8;i++) //搜索可直通的城市 if ((ju[a[head]][i]==0)(s[i]==0)) //判断城市是否走过 { tail++; //队尾加一,入队 a[tail]=i; b[tail]=head; s[i]=1; if (i==8) { out(tail);head=tail;break; //第一次搜到H城市时路线最短 } } }while (headtail); } int main() //主程序 { memset(s,false,sizeof(s)); doit(); //进行Bfs操作 return 0; } 【参考程序】 #includecstdio using namespace std; int dx[4]={-1,0,1,0}, dy[4]={0,1,0,-1}; int bz[100][100],num=0,n,m; void doit(int p,int q) { int x,y,t,w,i; int h[1000][10]; num++;bz[p][q]=0; t=0;w=1;h[1][1]=p;h[1][2]=q; //遇到的第一个细胞入队 do { t++; //队头指针加1 for (i=0;i=3;i++) //沿细胞的上下左右四个方向搜索细胞 { x=h[t][1]+dx[i];y=h[t][2]+dy[i]; if ((x=0)(xm)(y=0)(yn)(bz[x][y])) //判断该点是否可以入队

文档评论(0)

80019pp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档