水域大小(DFS)

2023-12-18 23:59
文章标签 大小 dfs 水域

本文主要是介绍水域大小(DFS),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 该题有点像做过的“岛屿数量”,也是标准的模板题,按照模板Go!!!!!!!!!!!!!

岛屿数量(DFS / BFS)_ZZZWWWFFF_的博客-CSDN博客

 

class Solution {
public:vector<int> v;int tx,ty,n,m,c=0,nextt[8][2]={{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1},{-1,0},{-1,1}};int dfs(vector<vector<int>>& land,int x,int y){if(land[x][y]==0){land[x][y]=-1;//走过的地方做记号c++;//水域数for(int i=0;i<8;i++){tx=x+nextt[i][0];ty=y+nextt[i][1];if(tx<0||ty<0||tx>=n||ty>=m){continue;}dfs(land,tx,ty);}}return c;}vector<int> pondSizes(vector<vector<int>>& land) {n=land.size();m=land[0].size();for(int i=0;i<n;i++){for(int j=0;j<m;j++){if(land[i][j]==0)//遇到水域就进入搜索并且计算水域数量{c=0;v.push_back(dfs(land,i,j));}}}sort(v.begin(),v.end());排序return v;}};

下面是我在题解中看到的一份我觉得不错的题解,分享给大家(大致思路差不多) 

class Solution {
public:vector<int> ret;int ans;vector<int> pondSizes(vector<vector<int>>& land) {for(int i=0;i<land.size();i++){for(int j=0;j<land[i].size();j++){if(!land[i][j]){ans = 0;dfs(land, i, j);ret.push_back(ans);}}}sort(ret.begin(),ret.end());return ret;}void dfs(vector<vector<int>>& land, int x, int y){if(x < 0 || x >= land.size() || y < 0 || y >= land[x].size() || land[x][y]){return;}if(!land[x][y]){ans++;}land[x][y]--;//走过做记号dfs(land, x-1, y);dfs(land, x-1, y-1);dfs(land, x-1, y+1);dfs(land, x, y-1);dfs(land, x, y+1);dfs(land, x+1, y-1);dfs(land, x+1, y);dfs(land, x+1, y+1);}
};

这篇关于水域大小(DFS)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510233

相关文章

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

ural 1149. Sinus Dances dfs

1149. Sinus Dances Time limit: 1.0 second Memory limit: 64 MB Let  An = sin(1–sin(2+sin(3–sin(4+…sin( n))…) Let  Sn = (…( A 1+ n) A 2+ n–1) A 3+…+2) An+1 For given  N print  SN Input One

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

深度优先(DFS)和广度优先(BFS)——算法

深度优先 深度优先搜索算法(英语:Depth-First-Search,DFS)是一种用于遍历或搜索树或图的算法。 沿着树的深度遍历树的节点,尽可能深的搜索树的分支,当节点v的所在边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点。这一过程一直进行到已发现从源节点可达的所有节点为止。如果还存在未被发现的节点,则选择其中一个作为源节点并重复以上过程,整个进程反复进行直到所有节点都被访

PDFQFZ高效定制:印章位置、大小随心所欲

前言 在科技编织的快节奏时代,我们不仅追求速度,更追求质量,让每一分努力都转化为生活的甜蜜果实——正是在这样的背景下,一款名为PDFQFZ-PDF的实用软件应运而生,它以其独特的功能和高效的处理能力,在PDF文档处理领域脱颖而出。 它的开发,源自于对现代办公效率提升的迫切需求。在数字化办公日益普及的今天,PDF作为一种跨平台、不易被篡改的文档格式,被广泛应用于合同签署、报告提交、证书打印等各个

【CSS in Depth 2 精译_024】4.2 弹性子元素的大小

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一章 层叠、优先级与继承(已完结) 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位(已完结) 2.1 相对单位的威力2.2 em 与 rem2.3 告别像素思维2.4 视口的相对单位2.5 无单位的数值与行高2.6 自定义属性2.7 本章小结 第三章 文档流与盒模型(已

Linux下获取硬盘空间的大小

1. df 命令查看所有硬盘设备的信息 2. 查看指定路径的磁盘空间大小 代码获取空间大小案例:

Windows11电脑上自带的画图软件修改照片大小(不裁剪尺寸的情况下)

针对一张图片,有时候上传的图片有大小限制,那么在这种情况下如何修改其大小呢,在不裁剪尺寸的情况下 步骤如下: 1.选定一张图片,右击->打开方式->画图,如下: 第二步:打开图片后,我们可以看到图片的大小为82.1kb,点击上面工具栏的“重设大小和倾斜”进行调整,如下: 第三步:修改水平和垂直的数字,此处我修改为分别都修改为50,然后保存,可以看到大小变成63.5kb,如下:

Oracle 查看表空间名称及大小和删除表空间及数据文件方法

--1、查看表空间的名称及大小  SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size  FROM dba_tablespaces t, dba_data_files d  WHERE t.tablespace_name = d.tablespace_name  GROUP BY t.tablespace_na