求助,bfs 代码死循环
  • 板块P1443 马的遍历
  • 楼主AFO1
  • 当前回复7
  • 已保存回复7
  • 发布时间2021/8/6 11:47
  • 上次更新2023/11/4 11:50:53
查看原帖
求助,bfs 代码死循环
250940
AFO1楼主2021/8/6 11:47
#include<bits/stdc++.h>
int n,m,xt,yt,minn[409][409],dx[8]={1,2,2,1,-1,-2,-2,1},dy[8]={2,1,-1,-2,-2,-1,1,2},v[409][409];
using namespace std;
struct node
{
	int x,y;
};
queue<node> q;
void bfs()
{
	v[xt][yt]=1;
	minn[xt][yt]=0;
	node l={xt,yt};
	q.push(l);
	while(!q.empty())
	{
		cout<<"&";
		node t=q.front();
		q.pop();
		for(int i=0;i<8;i++)
		{
			int xx=t.x+dx[i],yy=t.y+dy[i];
			if(xx>0&&yy>0&&!v[xx][yy])
			{
				minn[xx][yy]=minn[t.x][t.y]+1;
				node tt={xx,yy};
				q.push(tt);
				v[xx][yy]=1;
			}
		}
	}
}
int main()
{
	memset(minn,-1,sizeof(minn));
	cin>>n>>m>>xt>>yt;
	bfs();
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++) printf("%-5d",minn[i][j]);
		cout<<endl;
	}
	return 0;
}
2021/8/6 11:47
加载中...