#include <iostream> //BFS
#include <queue>
#include <cstring>
using namespace std;
struct node
{
int x;
int y;
node(){}
node(int xx,int yy):x(xx),y(yy){}
};
int n,m;
char g[20][20];
int visit[20][20];
int ans;
int dir[4][2]={
{0,1},{0,-1},{1,0},{-1,0}};
void bfs(node start)
{
queue<node>Q;
Q.push(start);
visit[start.x][start.y]=1;
++ans;
while(!Q.empty())
{
node temp=Q.front();
Q.pop();
for(int i=0;i<4;i++)
{
node np;np.x=temp.x+dir[i][0];np.y=temp.y+dir[i][1];
if(np.x>=0&&np.x<n&&np.y>=0&&np.y<m&&!visit[np.x][np.y]&&g[np.x][np.y]!='#')
{
visit[np.x][np.y]=1;
++ans;
Q.push(np);
}
}
}
}
int main()
{
while(c
poj1979 BFS/DFS
最新推荐文章于 2022-01-14 10:53:09 发布