水域大小(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

相关文章

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

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 本章小结 第三章 文档流与盒模型(已