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             else
36                 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 }

转载于:https://www.cnblogs.com/BMESwimming/p/3851871.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值