1. 你有一张某海域NxN像素的照片,"."表示海洋、"#"表示陆地,如下所示:
  2. .......
  3. .##....
  4. .##....
  5. ....##.
  6. ..####.
  7. ...###.
  8. .......
  9. 其中"上下左右"四个方向上连在一起的一片陆地组成一座岛屿。例如上图就有2座岛屿。
  10. 由于全球变暖导致了海面上升,科学家预测未来几十年,岛屿边缘一个像素的范围会被海水淹没。具体来说如果一块陆地像素与海洋相邻(上下左右四个相邻像素中有海洋),它就会被淹没。
  11. 例如上图中的海域未来会变成如下样子:
  12. .......
  13. .......
  14. .......
  15. .......
  16. ....#..
  17. .......
  18. .......
  19. 请你计算:依照科学家的预测,照片中有多少岛屿会被完全淹没。
  20.  
  21. 输入格式
  22. 第一行包含一个整数N ( <= N <= )
  23. 以下NN列代表一张海域照片。
  24. 照片保证第1行、第1列、第N行、第N列的像素都是海洋。
  25. 输出格式
  26. 一个整数表示答案
  27. 输入样例

  28. .......
  29. .##....
  30. .##....
  31. ....##.
  32. ..####.
  33. ...###.
  34. .......
  35. 输出样例

我拿到这题肯定知道是搜索,但是题目的意思让我匪夷所思,后来慢慢才懂题目的意思。懂了之后,和大多数人的想法一样,两遍dfs搜索找遍全球变暖前后的岛屿数然后相减就是最后的答案。

有篇博主的答案给的代码让我觉得他的想法挺惊艳的,既然求照片中有多少岛屿会被完全淹没,那么只需要找出那些在搜索过程中岛屿上的土地周围都存在海水的岛屿就好了,至于其他有那种四周都有土地的岛屿,它最后只剩一块土地也好,它分成2,3个岛屿也罢,我都不需要去管

另外,那个源代码有挺多问题的,我改了一下,开始没注意到边界问题,程序直接崩了

  1. #include<iostream>
  2. #include<cstdio>
  3. #include <algorithm>
  4. #include <cstring>
  5. using namespace std;
  6. int n;
  7. char map[][];
  8. int ans[];
  9. int vis[][];
  10.  
  11. void dfs(int x, int y, int k)
  12. {
  13. if(map[x][y]=='.'||vis[x][y]||x<||y<||x>=n||y>=n)
  14. return;
  15. vis[x][y]=;
  16. if(map[x-][y]=='#'&&map[x+][y]=='#'&&map[x][y-]=='#'&&map[x][y+]=='#')
  17. ans[k]++;
  18. dfs(x+, y, k);
  19. dfs(x-, y, k);
  20. dfs(x, y-, k);
  21. dfs(x, y+, k);
  22. }
  23. int main()
  24. {
  25. memset(vis, , sizeof(vis));
  26. scanf("%d", &n);
  27. for(int i = ; i < n; i++)
  28. scanf("%s", &map[i]);
  29.  
  30. int cnt=;
  31. for(int i = ; i < n; i++) {
  32. for(int j = ; j < n; j++) {
  33. if(map[i][j]=='#'&&!vis[i][j]) {
  34. dfs(i, j, cnt);
  35. cnt++;
  36. }
  37. }
  38. }
  39.  
  40. int sum=;
  41. for(int i = ; i < cnt; i++)
  42. if(ans[i]==)
  43. sum++;
  44. printf("%d\n",sum);
  45.  
  46. return ;
  47. }

参考自:https://www.cnblogs.com/flightless/p/8718443.html

DFS_全球变暖_蓝桥杯2018省赛N0.9的更多相关文章

  1. Java 第十一届 蓝桥杯 省模拟赛 小明的城堡

    小明用积木搭了一个城堡. 为了方便,小明在搭的时候用的是一样大小的正方体积本,搭在了一个 n 行 m 列的方格图上,每个积木正好占据方格图的一个小方格. 当然,小明的城堡并不是平面的,而是立体的.小明 ...

  2. Java 第十一届 蓝桥杯 省模拟赛 梅花桩

    小明每天都要练功,练功中的重要一项是梅花桩. 小明练功的梅花桩排列成 n 行 m 列,相邻两行的距离为 1,相邻两列的距离也为 1. 小明站在第 1 行第 1 列上,他要走到第 n 行第 m 列上.小 ...

  3. Java 第十一届 蓝桥杯 省模拟赛 元音字母辅音字母的数量

    给定一个单词,请计算这个单词中有多少个元音字母,多少个辅音字母. 元音字母包括 a, e, i, o, u,共五个,其他均为辅音字母. 输入格式 输入一行,包含一个单词,单词中只包含小写英文字母. 输 ...

  4. Java 第十一届 蓝桥杯 省模拟赛 递增序列

    问题描述 在数列 a[1], a[2], -, a[n] 中,如果 a[i] < a[i+1] < a[i+2] < - < a[j],则称 a[i] 至 a[j] 为一段递增 ...

  5. Java 第十一届 蓝桥杯 省模拟赛 最大的元素距离

    在数列 a_1, a_2, -, a_n中,定义两个元素 a_i 和 a_j 的距离为 |i-j|+|a_i-a_j|,即元素下标的距离加上元素值的差的绝对值,其中 |x| 表示 x 的绝对值. 给定 ...

  6. Java 第十一届 蓝桥杯 省模拟赛 洁净数

    洁净数 小明非常不喜欢数字 2,包括那些数位上包含数字 2 的数.如果一个数的数位不包含数字 2,小明将它称为洁净数. 请问在整数 1 至 n 中,洁净数有多少个? 输入格式 输入的第一行包含一个整数 ...

  7. Java 第十一届 蓝桥杯 省模拟赛 第十层的二叉树

    一棵10层的二叉树,最多包含多少个结点? 注意当一棵二叉树只有一个结点时为一层. 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余 ...

  8. Java 第十一届 蓝桥杯 省模拟赛 70044与113148的最大公约数

    问题描述 70044与113148的最大公约数是多少? 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分. pac ...

  9. Java 第十一届 蓝桥杯 省模拟赛 19000互质的个数

    问题描述 不超过19000的正整数中,与19000互质的数的个数是多少? 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将 ...

随机推荐

  1. javascript“命名空间”的费曼输出[原创]

    Javascript由于没有命名空间的概念,所以好多的框架或库就用了某些“命名空间”的技巧.在学习作为函数的命名空间时,我翻阅了好多的书本和blog,很多的概念和说明都是要么过于烦杂或过于简单.现在由 ...

  2. 高并发 Nginx+Lua OpenResty系列(4)——Lua 模块开发

    在实际开发中,不可能把所有代码写到一个大而全的lua文件中,需要进行分模块开发:而且模块化是高性能Lua应用的关键.使用require第一次导入模块后,所有Nginx 进程全局共享模块的数据和代码,每 ...

  3. js获取radio选中索引值

    <form name="form1" onsubmit="return foo()"> <input type="radio&quo ...

  4. MySQL的登录与退出以及MySQL的目录结构

    一.MySQL的登录 1.利用语句mysql -uroot -proot 同时如果密码不想让别人看到,可以在-p处直接回车,再输入密码就是加密的了 2.远程登录 以连接本地为例 此处涉及到localh ...

  5. CentOS 7更新系统时间

    Linux系统在安装的时候,总是会出现时区,时间的错误. 将Linux系统时间和本地区网络时间同步,ntpdate可以从网络同步时间, 需要安装sudo yum install ntp ntpdate ...

  6. 并发编程-concurrent指南-阻塞双端队列-链阻塞双端队列LinkedBlockingDeque

    LinkedBlockingDeque是双向链表实现的阻塞队列.该阻塞队列同时支持FIFO和FILO两种操作方式,即可以从队列的头和尾同时操作(插入/删除): 在不能够插入元素时,它将阻塞住试图插入元 ...

  7. django基础知识之布署:

    布署 从uwsgi.nginx.静态文件三个方面处理 服务器介绍 服务器:私有服务器.公有服务器 私有服务器:公司自己购买.自己维护,只布署自己的应用,可供公司内部或外网访问 公有服务器:集成好运营环 ...

  8. C++11/14笔记

    目录 语言层面 模板表达式中的空格 nullptr和std::nullptr_t 自动推导类型----auto 一致性初始化----Uniform Initialization 初始化列表(initi ...

  9. Altium Designer设计PCB--如何增大电源地的线宽

    笑话: 看见楼下老大爷在下棋,我看了一会儿,跟大爷说:大爷,你che没了. 大爷一脸不屑:小朋友,那叫ju. 然后我静静地在那看了两个小时. 对完棋,大爷起身要走. 我说:大爷,我刚才说的不是你的棋, ...

  10. 『开发技术』Docker开发教程(一)安装与测试(Windows 家庭版)

    0.前言 针对其他系统和版本,Docker都很容易安装,可以参考官方教程:https://docs.docker.com/docker-hub/ 由于Windows10家庭版无法安装docker,因此 ...