当前位置: 首页 > news >正文

大连哪里有手机自适应网站建设欧美化妆品网站模板下载

大连哪里有手机自适应网站建设,欧美化妆品网站模板下载,淘宝app官网,自助建站教程全球变暖问题 文章目录 全球变暖问题前言题目描述题目分析边界问题的考虑岛屿是否被淹没判断:如何寻找联通块: 代码预告 前言 之前我们介绍了 bfs算法在二维,三维地图中的应用,现在我们接续进行拓展,解锁floodfill 算…

全球变暖问题

文章目录

  • 全球变暖问题
    • 前言
    • 题目描述
    • 题目分析
      • 边界问题的考虑
      • 岛屿是否被淹没判断:
      • 如何寻找联通块:
    • 代码
    • 预告

前言

之前我们介绍了 bfs算法在二维,三维地图中的应用,现在我们接续进行拓展,解锁floodfill 算法,准确的来说是用 bfs算法解决联通块问题。后续还会更新 bfs算法有关内容,喜欢的小伙伴可以点个关注啦。

题目描述

你有一张某海域 N×N 像素的照片,”.”表示海洋、”#”表示陆地,如下所示:

.......
.##....
.##....
....##.
..####.
...###.
.......

其中”上下左右”四个方向上连在一起的一片陆地组成一座岛屿,例如上图就有 2 座岛屿。

由于全球变暖导致了海面上升,科学家预测未来几十年,岛屿边缘一个像素的范围被海水淹没。

具体来说如果一块陆地像素与海洋相邻(上下左右四个相邻像素中有海洋),它就会被淹没。

例如上图中的海域未来会变成如下样子:

.......
.......
.......
.......
....#..
.......
.......

请你计算:依照科学家的预测,照片中有多少岛屿会被完全淹没。

输入格式
第一行包含一个整数N。

以下 N 行 N 列,包含一个由字符”#”和”.”构成的 N×N 字符矩阵,代表一张海域照片,”#”表示陆地,”.”表示海洋。

照片保证第 1 行、第 1 列、第 N 行、第 N 列的像素都是海洋。

输出格式
一个整数表示答案。

数据范围
1≤N≤1000
输入样例1:
7

.......
.##....
.##....
....##.
..####.
...###.
.......

输出样例1:
1
输入样例2:

9
.........
.##.##...
.#####...
.##.##...
.........
.##.#....
.#.###...
.#..#....
.........

输出样例2:
1

题目分析

边界问题的考虑

照片保证第 1 行、第 1 列、第 N 行、第 N 列的像素都是海洋。

这里想要不考虑边界问题,输入的初始下标要设为 1 开始,这样就可以保证数组不越界,并且由题目的意思可得,外围的圈都是海洋,只要下标从1 开始,我们就可以不用考虑bfs算法当中的边界问题。

岛屿是否被淹没判断:

如何判定这是一个不会被淹没的岛屿呢?
首先我们要明白联通块的概念------连在一起的快;
接着我们定义一个沿岸元素

具体来说如果一块陆地像素与海洋相邻(上下左右四个相邻像素中有海洋),它就会被淹没。

也就是说只要一个‘#’旁边有海洋,我们就可以认定该陆地元素‘#’是沿岸元素块。
只要我们的联通块的所有总数=沿岸元素的所有总数,那么我们就可以判定这是个会被淹没的岛屿

如何寻找联通块:

答案就是利用我们的 bfs算法将目标元素进行宽度优先搜索,将搜索到的的‘#’,标记,继续搜索那些没有被标记的‘#’

代码

详细的解释都在代码的注释里头啦

#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
const int N =1e3 + 7;
char g[N][N];//用来存放地图
bool st[N][N];//用来统计那些点已经被搜索过了
int dx[4]={-1,0,1,0};
int dy[4]={0,1,0,-1};
typedef pair<int,int> PII;
void bfs(int i,int j,int &total,int &bound){
//这里使用的引用符号是&,要将值传回去。st[i][j]=true;queue<PII> q;q.push({i,j});while(!q.empty()){auto t=q.front();q.pop();total++;bool flag=false;//这个flag用于沿岸元素的判断for(int i=0;i<4;i++){int x=t.first+dx[i];int y=t.second+dy[i];if(g[x][y]=='#' && !st[x][y]){q.push({x,y});st[x][y]=true;}if(g[x][y]=='.'){//只要有一个旁边元素是‘.’就可以判断其为沿岸元素flag=true;}}if(flag) bound++;//如果判断成功,沿岸元素++}
}
int main(){int n;cin>>n;memset(g,'.',sizeof g);//在题目分析中的说明里,//这个代码可要可不要,假如没有题目中的话,我们就要加上这行代码了for(int i=1;i<=n;i++) cin>>g[i];int res=0;for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(!st[i][j] && g[i][j]=='#'){int total=0,bound=0;bfs(i,j,total,bound);if(total==bound) res++;//判断这个岛屿是否会被淹没}}}cout<<res<<endl;return 0;
}

预告

后期还放出大学生 web大作业【制作一个门户网站】,感兴趣的小伙伴可以点个关注啦

http://www.yayakq.cn/news/819669/

相关文章:

  • 建设网站遇到问题的解决方案沈阳关键词优化价格
  • wordpress 微信导航站学做网站要懂英语吗
  • opencart zencart网站建设百度关键词权重查询
  • 做动图的网站东莞优化公司首选3火星
  • 小说网站的阅读界面怎么做的html旅游网页设计代码
  • php 网站 手机版网站文章内容优化方案
  • 上海频道网站建设长春h5建站模板
  • 外贸做网站建设哪家好宁波seo关键词优化报价
  • 网站被人做跳转做外贸最好的网站
  • 天津微信网站开发外贸建站网站推广
  • 网站开发常用单词苏州专业网站建设开发公司
  • 网站建设术语wordpress 不同分类
  • 百度网站架构手机h5建网站
  • 网站建设前WordPress页面支持文件上传
  • 上海哪家网站建设好coupang入驻费用
  • 南充网站建设制作企业网站站内优化
  • 西安高端网站建设首选河南旅游网站建设
  • 建网站多少钱建个网站需要怎么做网站建设设计文档模板下载
  • 网站开发前景好吗电商网站建设要多少钱
  • 做网站要用写接口6雄安新区做网站公司
  • 网站做什么内容赚钱北京网站建设 爱牛
  • 自己做网站iis设置白山网站建设公司
  • 深圳前十网站扩广公司wordpress 所有函数
  • 电脑自带的做网站叫什么自适应网站建设价格
  • 现在还有网站做校内网吗怎么自己做网站发优惠券
  • 做网站补贴网页制作接单
  • 餐饮品牌设计网站建设太原区域调整最新消息
  • 公司营销网站怎么做免费做网站tk
  • 计算机网站开发开题报告范文上海seo排名
  • 山南网站建设网站标题有特殊符号