首页 > 代码库 > ZOJ - 2165 Red and Black
ZOJ - 2165 Red and Black
BFS题,只是没有目标位置,只需记下走过的黑色的块数就行
1 #include<stdio.h> 2 #include<string.h> 3 const int maxn=1000,maxm=25; 4 int vis[maxm][maxm],mat[maxm][maxm],dir[5][3]={{1,0},{0,-1},{-1,0},{0,1}}; 5 int w,h; 6 char s[maxm][maxm]; 7 struct node{ 8 int xpos; 9 int ypos;10 int step;11 void init(int x,int y,int z)12 {13 xpos=x;14 ypos=y;15 step=z;16 }17 }que[maxn];18 int bfs(node sour);19 int main()20 {21 while(scanf("%d%d",&w,&h)==2 && w && h){22 node source;23 for(int i=0;i<h;i++)24 scanf("%s",s[i]);25 memset(mat,0,sizeof(mat));26 for(int i=0;i<h;i++)27 for(int j=0;j<w;j++){28 if(s[i][j]==‘#‘)29 mat[i][j]=1;30 else if(s[i][j]==‘@‘){31 mat[i][j]=0;32 source.xpos=i;33 source.ypos=j;34 }35 else36 continue;37 }38 int maxsteps=bfs(source);39 printf("%d\n",maxsteps);40 }41 return 0;42 }43 int bfs(node sour)44 {45 int maxsteps=1;46 sour.step=1;47 int head,tail;48 que[head=tail=0]=sour;49 tail++;50 memset(vis,0,sizeof(vis));51 vis[sour.xpos][sour.ypos]=1;52 while(head!=tail){53 node a=que[head];54 for(int i=0;i<4;i++){55 int nx=a.xpos+dir[i][0];56 int ny=a.ypos+dir[i][1];57 if(nx>=h || ny>=w || nx<0 || ny<0)58 continue;59 if(vis[nx][ny])60 continue;61 if(mat[nx][ny])62 continue;63 node c;64 c.init(nx,ny,a.step+1);65 que[tail]=c;66 vis[nx][ny]=1;67 maxsteps++;68 tail=(tail+1)%maxn;69 }70 head=(head+1)%maxn;71 }72 return maxsteps;73 }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。