HDU 1312 Red and Black <BFS>_red and black hdu - 1312 c语言解析

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

.#.#…#.
.#.#.###.#.
.#.#…@#.#.
.#.#####.#.
.#…#.
.#########.

11 6
…#…#…#…
…#…#…#…
…#…#…###
…#…#…#@.
…#…#…#…
…#…#…#…
7 7
…#.#…
…#.#…
###.###
…@…
###.###
…#.#…
…#.#…
0 0




   

  


 Sample Output 


45
59
6
13


  


又是一道可以用BFS和DFS 的题,这里写的是BFS求解,套模板就好了,只不过不要忽略题目说的一句话,答案是包括起点的,所以定义的结果初始设为1,设为0的时候如果全局就只有一个黑色起点,BFS扩展不下去,结果输出了0,但是除了这种情况其他的情况都能得到正确答案,在这个地方WA了很多次,所以一定要看清楚题目  
 


  
 




#include
#include
#include
#include
#include
#include
#include
#include
#include
#include

const double eps=1e-8;
const double PI=acos(-1.0);
using namespace std;

struct Node{
int x,y;
}node;

int n,m;
char a[50][50];
int c[][2]={{0,1},{1,0},{0,-1},{-1,0}};

void bfs(int i,int j){
int ans=1;//初值设为1
queue q;
node.x=i;
node.y=j;
a[i][j]=‘#’;
q.push(node);
while(!q.empty()){
Node temp,tp=q.front();
q.pop();
for(int k=0;k<4;k++){
temp.x=tp.x+c[k][0];
temp.y=tp.y+c[k][1];
if(temp.x<m&&temp.y<n&&temp.x>=0&&temp.y>=0&&a[temp.x][temp.y]!=‘#’){
ans++;
q.push(temp);
a[temp.x][temp.y]=‘#’;
}
}

}
printf("%d\n",ans);

}

int main()
{
while(~scanf(“%d%d”,&n,&m)&&(n||m))
{
int p1,p2;
for(int i=0; i<m; i++)
{
scanf(“%s”,a[i]);
}
for(int i=0;i<m;i++)
for(int j=0; j<n; j++)
{

            if(a[i][j]=='@'){
                p1=i,p2=j;
                break;
            }
        }
    bfs(p1,p2);
  //  printf("%d\n",ans);
}
return 0;

}


  

  




![img](https://img-blog.csdnimg.cn/img_convert/54c4e8c2d108c12e280cb403545f4f51.png)
![img](https://img-blog.csdnimg.cn/img_convert/5f11932a1e7a4776e001d957528a41bf.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618668825)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618668825)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值