【leetcode100-051到054】【图论】四题合集

2024-01-23 14:36

本文主要是介绍【leetcode100-051到054】【图论】四题合集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【岛屿数量】

给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。

岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。

此外,你可以假设该网格的四条边均被水包围。

思路:

很经典也很基础的图搜题,bfs或者dfs都行,这题先用dfs写一下。

每次开启函数(而不是被递归调用),会将当前起点能接触到的所有陆地都访问一次再退出,记录函数开启的次数即可。

对每个格子,我们向上下左右四个方向拓展,对其中位置合法的、是陆地的、还没被访问过的格子进行递归调用,直到所有能访问的格子都访问完毕。

代码其实跟树的dfs也大同小异,区别只在出口的判断条件,以及可能递归的方向从两颗子树变成了四个方向(网格的情况,普通图的话就是变成所有neighbors)。

class Solution {
public://合法性判断bool inArea(vector<vector<char>>& grid, int r, int c) {return 0 <= r && r < grid.size() && 0 <= c && c < grid[0].size();}// dfsvoid dfs(vector<vector<char>>& grid, int r, int c) {//不合法if (!inArea(grid, r, c))return;//来过了if (grid[r][c] != '1')return;//标记并扩展grid[r][c] = '2';dfs(grid, r - 1, c);dfs(grid, r + 1, c);dfs(grid, r, c - 1);dfs(grid, r, c + 1);}int numIslands(vector<vector<char>>& grid) {int ans = 0;for (int r = 0; r < grid.size(); r++) {for (int c = 0; c < grid[0].size(); c++) {if (grid[r][c] == '1') {dfs(grid, r, c);ans++;}}}return ans;}
};

【腐烂的橘子】

在给定的 m x n 网格 grid 中,每个单元格可以有以下三个值之一:

  • 值 0 代表空单元格;
  • 值 1 代表新鲜橘子;
  • 值 2 代表腐烂的橘子。

每分钟,腐烂的橘子 周围 4 个方向上相邻 的新鲜橘子都会腐烂。

返回 直到单元格中没有新鲜橘子为止所必须经过的最小分钟数。如果不可能,返回 -1 。

思路:

看到最短时间,想必也知道这题很可能是要选bfs了。

理论上来说应该是要重新开辟空间来记录橘子的腐烂时间的,但我发现这题把原数组处理一下就可以直接使用而且不用担心信息丢失的问题。

剩下思路直接看注释,这题的注释我写得可认真啦。

class Solution {
public:int orangesRotting(vector<vector<int>>& grid) {//建立记录腐烂时间的数组,或改造原数组// vector<vector<int> > visited(m, vector<int>(n, -1));//顺便把初始腐烂的橘子入队queue<pair<int, int>> q;for (int i = 0; i < grid.size(); i++) {for (int j = 0; j < grid[0].size(); j++) {grid[i][j] -= 2;if (grid[i][j] == 0)q.push(make_pair(i, j));}}//取一个烂橘子,把四周还新鲜的橘子污染,记录污染时间,并把新的烂橘子入队,直到没有待处理的烂橘子int curTime = 0, r = 0, c = 0;int rMax = grid.size(), cMax = grid[0].size();while (!q.empty()) {//取auto cur = q.front();q.pop();r = cur.first;c = cur.second;curTime = grid[r][c];//污染if (0 <= r - 1 && grid[r - 1][c] == -1) {q.push(make_pair(r - 1, c));grid[r - 1][c] = curTime + 1;}if (r + 1 < rMax && grid[r + 1][c] == -1) {q.push(make_pair(r + 1, c));grid[r + 1][c] = curTime + 1;}if (0 <= c - 1 && grid[r][c - 1] == -1) {q.push(make_pair(r, c - 1));grid[r][c - 1] = curTime + 1;}if (c + 1 < cMax && grid[r][c + 1] == -1) {q.push(make_pair(r, c + 1));grid[r][c + 1] = curTime + 1;}}//检查有无新鲜橘子剩下,顺便找最大时间int maxTime = 0;for (int i = 0; i < grid.size(); i++) {for (int j = 0; j < grid[0].size(); j++) {if (grid[i][j] == -1)return -1;maxTime = max(maxTime, grid[i][j]);}}return maxTime;}
};

【课程表】

你这个学期必须选修 numCourses 门课程,记为 0 到 numCourses - 1 。

在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出,其中 prerequisites[i] = [ai, bi] ,表示如果要学习课程 ai 则 必须 先学习课程  bi 。

  • 例如,先修课程对 [0, 1] 表示:想要学习课程 0 ,你需要先完成课程 1 。

请你判断是否可能完成所有课程的学习?如果可以,返回 true ;否则,返回 false 。

思路:

从这题开始离开了美好的网格,变成了普通的图,好在这是一个超经典拓扑序列题,我们捋一下拓扑序列的思路就好了。

  • 建立入度表,出边表,存储当前可上课程的队列,已上课的数量;
  • 入度为零的是当前可以上的课,把它入队;
  • 每次从队列中取一节可以上的课,把它上了,已上课数量++;
  • 把这门课出边表里的邻居节点的入度都减一,如果减到零那么该邻居也可以上了,把它入队;
  • 当队伍空了,说明当前没有可以上的课了,检查已上课数量和应上课数量,就可以知道答案。
class Solution {
public:bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {//建立入度表vector<int> inDegree(numCourses, 0);//建立出边表unordered_map<int, vector<int>> outTable;//记录数据for (int i = 0; i < prerequisites.size(); i++) {inDegree[prerequisites[i][0]]++;outTable[prerequisites[i][1]].push_back(prerequisites[i][0]);}//建立可上课队列queue<int> q;//把当前能上的课入队for (int i = 0; i < numCourses; i++) {if (inDegree[i] == 0)q.push(i);}//计数int cnt = 0;//队列不空(还有课能上)时循环while (!q.empty()) {//取出一门,上,计数,出边表里的课全都减入度,减到0的入队int cur = q.front();q.pop();cnt++;for (int i = 0; i < outTable[cur].size(); i++) {if (--inDegree[outTable[cur][i]] == 0)q.push(outTable[cur][i]);}}//对比计数,返回结果return cnt == numCourses;}
};

【前缀树】

Trie(发音类似 "try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的键。这一数据结构有相当多的应用情景,例如自动补完和拼写检查。

请你实现 Trie 类:

  • Trie() 初始化前缀树对象。
  • void insert(String word) 向前缀树中插入字符串 word 。
  • boolean search(String word) 如果字符串 word 在前缀树中,返回 true(即,在检索之前已经插入);否则,返回 false 。
  • boolean startsWith(String prefix) 如果之前已经插入的字符串 word 的前缀之一为 prefix ,返回 true ;否则,返回 false 。

思路:

数据结构类的题好像没什么思路可言,倒是对熟练c++面向对象思想挺有帮助的。本题精髓在于26格的next数组,直接看代码吧。

class Trie {
private:bool isEnd;Trie* next[26];public:Trie() {isEnd = false;for (int i = 0; i < 26; i++) {next[i] = nullptr;}}void insert(string word) {Trie* cur = this;for (char c : word) {if (cur->next[c - 'a'] == nullptr) {cur->next[c - 'a'] = new Trie();}cur = cur->next[c - 'a'];}cur->isEnd = true;}bool search(string word) {Trie* cur = this;for (char c : word) {if (cur->next[c - 'a'] == nullptr)return false;cur = cur->next[c - 'a'];}return cur->isEnd;}bool startsWith(string prefix) {Trie* cur = this;for (char c : prefix) {if (cur->next[c - 'a'] == nullptr)return false;cur = cur->next[c - 'a'];}return true;}
};

这篇关于【leetcode100-051到054】【图论】四题合集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

新160个crackme - 051-Keygenning4newbies

运行分析 需要破解Name和Serial PE分析 C++程序,32位,无壳 静态分析&动态调试 ida找到关键字符串,双击进入函数 静态分析得到以下结论:1、Name长度要大于4,小于502、v5 += Name[i] ^ (i + 1)3、v7 = 最后一个Name[i] ^ (i + 1)4、Serial = (v5<<7) + 6* v7 的16进制

C++语法知识点合集:11.模板

文章目录 一、非类型模板参数1.非类型模板参数的基本形式2.指针作为非类型模板参数3.引用作为非类型模板参数4.非类型模板参数的限制和陷阱:5.几个问题 二、模板的特化1.概念2.函数模板特化3.类模板特化(1)全特化(2)偏特化(3)类模板特化应用示例 三、模板分离编译1.概念2.模板的分离编译 模版总结 一、非类型模板参数 模板参数分类类型形参与非类型形参 非类型模板

Linux性能分析工具合集

Linux性能分析工具合集 工具合集主要包含以下各种工具,对于了解Linux系统结构、网络结构、内核层次具有一定的帮助。 Linux Performance Observability ToolsLinux Static Performance ToolsLinux Performance Benchmark ToolsLinux Performance Tuning ToolsLinux

JVM合集

序言: 1.什么是JVM? JVM就是将javac编译后的.class字节码文件翻译为操作系统能执行的机器指令翻译过程: 前端编译:生成.class文件就是前端编译后端编译:通过jvm解释(或即时编译或AOT)执行.class文件时跨平台的,jvm并不是跨平台的通过javap进行反编译 2.java文件是怎么变成.class文件的? 属于前端编译 3..class文件解读 采用1

C语言程序与设计第四版课后习题 - 1~8章大合集

前言 本文章是一个大合集,按照课后习题的命名方式命名,方便寻找,只需要在目录上点相对应的题号即可在这里插入图片描述 第一章课后习题 1.1 编写一个C程序 题目概述: 请参照本章例题,编写一个C程序,输出一下信息: *****************************Very good!***************************** 代码实现: #define

【代码随想录训练营第42期 续Day52打卡 - 图论Part3 - 卡码网 103. 水流问题 104. 建造最大岛屿

目录 一、做题心得 二、题目与题解 题目一:卡码网 103. 水流问题 题目链接 题解:DFS 题目二:卡码网 104. 建造最大岛屿 题目链接 题解:DFS  三、小结 一、做题心得 也是成功补上昨天的打卡了。 这里继续图论章节,还是选择使用 DFS 来解决这类搜索问题(单纯因为我更熟悉 DFS 一点),今天补卡的是水流问题和岛屿问题。个人感觉这一章节题对于刚

《黑神话:悟空》专题合集MOD/修改器/壁纸/音乐/CG剧情

《黑神话:悟空》专题合集」 链接:https://pan.quark.cn/s/d67857f4e308 包含内容: 《黑神话:悟空》MOD合集 《黑神话:悟空》修改器(风灵月影) 《黑神话:悟空》壁纸合集 《黑神话:悟空》3小时CG完整剧情合集 4K120帧最高画质!国语 简中字幕 附:4K 结尾动画合集 ​​​国语 简中字幕 《黑神话:悟空》主题曲 《黑神话

【鼠鼠学AI代码合集#5】线性代数

在前面的例子中,我们已经讨论了标量的概念,并展示了如何使用代码对标量进行基本的算术运算。接下来,我将进一步说明该过程,并解释每一步的实现。 标量(Scalar)的基本操作 标量是只有一个元素的数值。它可以是整数、浮点数等。通过下面的 Python 代码,我们可以很容易地进行标量的加法、乘法、除法和指数运算。 代码实现: import torch# 定义两个标量x = torch.tens