【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;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/641112.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java线程池七大参数详解和配置(面试重点)

一、corePoolSize核心线程数 二、maximunPoolSize最大线程数 三、keepAliveTime空闲线程存活时间 四、unit空闲线程存活时间的单位 五、workQueue线程工作队列 1、ArrayBlockingQueue FIFO有界阻塞队列 2、LinkedBlockingQueue FIFO无限队列 3、PriorityBlockingQueue V…

【代码随想录】刷题笔记Day54

前言 差单调栈就结束代码随想录一刷啦&#xff0c;回家二刷打算改用python补充进博客&#xff0c;小涛加油&#xff01;&#xff01;&#xff01; 647. 回文子串 - 力扣&#xff08;LeetCode&#xff09; 双指针法 中心点外扩&#xff0c;注意中心点可能有一个元素可能有两个…

neo4j jdk17下 dump 报错

更换jdk版本 只需要改下bin目录下的neo4j.bat, 把set "JAVA_HOMEXXXX"加入进去就行 windows SET "JAVA_HOMEc:\...." linux bin目录下 neo4j 在首行添加JAVA_HOME/usr/local/jdk文件夹即可 tomcat 指定jdk 找到bin下的setclasspath.bat文件&#xff1b;在…

Supervised Contrastive 损失函数详解

有什么不对的及时指出&#xff0c;共同学习进步。(●’◡’●) 有监督对比学习将自监督批量对比方法扩展到完全监督设置&#xff0c;能够有效地利用标签信息。属于同一类的点簇在嵌入空间中被拉到一起&#xff0c;同时将来自不同类的样本簇推开。这种损失显示出对自然损坏很稳…

【Linux C | 进程】进程终止、等待 | exit、_exit、wait、waitpid

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

【Kafka】开发实战和Springboot集成kafka

目录 消息的发送与接收生产者消费者 SpringBoot 集成kafka服务端参数配置 消息的发送与接收 生产者 生产者主要的对象有&#xff1a; KafkaProducer &#xff0c; ProducerRecord 。 其中 KafkaProducer 是用于发送消息的类&#xff0c; ProducerRecord 类用于封装Kafka的消息…

C 练习实例39

题目&#xff1a;有一个已经排好序的数组。现输入一个数&#xff0c;要求按原来的规律将它插入数组中。 代码&#xff1a; #include <stdio.h> #define N 10 int main() {int a[N]{1,3,5,7,9,11,13,15,17}; //元素数组int nN;int i,temp;printf("原始数组是:\n&qu…

仅使用K-M法+Cox比例风险模型就能发二区文章 | SEER公共数据库周报(1.17)

欢迎各位参加本周中山大学著名卫生统计学家方积乾教授公益直播讲座&#xff01; 就在本周三晚&#xff0c;主题为“真实世界研究与RCT研究”&#xff0c;欢迎各位预约参加&#xff01; SEER&#xff08;The Surveillance, Epidemiology, and End Results&#xff09;数据库是由…

回溯算法篇-01:全排列

力扣46&#xff1a;全排列 题目分析 这道题属于上一篇——“回溯算法解题框架与思路”中的 “元素不重复不可复用” 那一类中的 排列类问题。 我们来回顾一下当时是怎么说的&#xff1a; 排列和组合的区别在于&#xff0c;排列对“顺序”有要求。比如 [1,2] 和 [2,1] 是两个不…

【AI】深度学习在编码中的应用(10)

目录 先看2个定义&#xff1a;P帧和B帧 基于层次学习的高效视频压缩技术 基于B帧的B-EPIC方法 今天来学习编码配置优化技术。 先看2个定义&#xff1a;P帧和B帧 在视频压缩中&#xff0c;P帧和B帧都是关键的概念&#xff0c;它们与I帧一起构成了视频压缩的三种基本帧类型。…

柔性数组和C语言内存划分

柔性数组和C语言内存划分 1. 柔性数组1.1 柔性数组的特点&#xff1a;1.2 柔性数组的使用1.3 柔性数组的优势 2. 总结C/C中程序内存区域划分 1. 柔性数组 也许你从来没有听说过柔性数组&#xff08;flexible array)这个概念&#xff0c;但是它确实是存在的。 C99 中&#xff…

力扣740. 删除并获得点数

动态规划 思路&#xff1a; 选择元素 x&#xff0c;获得其点数&#xff0c;删除 x 1 和 x - 1&#xff0c;则其他的 x 的点数也会被获得&#xff1b;可以将数组转换成一个有序 map&#xff0c;key 为 x&#xff0c; value 为对应所有 x 的和&#xff1b;则问题转换成了不能同…

Postman基本使用、测试环境(Environment)配置

文章目录 准备测试项目DemoController测试代码Interceptor模拟拦截配置 Postman模块简单介绍Postman通用环境配置新建环境(Environment)配置环境(Environment)设置域名变量引用域名变量查看请求结果打印 Postman脚本设置变量登录成功后设置全局Auth-Token脚本编写脚本查看conso…

即插即用篇 | UniRepLKNet:用于音频、视频、点云、时间序列和图像识别的通用感知大卷积神经网络 | DRepConv

大卷积神经网络(ConvNets)近来受到了广泛研究关注,但存在两个未解决且需要进一步研究的关键问题。1)现有大卷积神经网络的架构主要遵循传统ConvNets或变压器的设计原则,而针对大卷积神经网络的架构设计仍未得到解决。2)随着变压器在多个领域的主导地位,有待研究ConvNets…

软件设计师——项目管理(一)

&#x1f4d1;前言 本文主要是【项目管理】——软件设计师——项目管理的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304…

Databend 开源周报第 129 期

Databend 是一款现代云数仓。专为弹性和高效设计&#xff0c;为您的大规模分析需求保驾护航。自由且开源。即刻体验云服务&#xff1a;https://app.databend.cn 。 Whats On In Databend 探索 Databend 本周新进展&#xff0c;遇到更贴近你心意的 Databend 。 支持标准流 标…

如何在 Ubuntu 22.04 上安装 Apache Web 服务器

前些天发现了一个人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;最重要的屌图甚多&#xff0c;忍不住分享一下给大家。点击跳转到网站。 如何在 Ubuntu 22.04 上安装 Apache Web 服务器 介绍 Apache HTTP 服务器是世界上使用最广泛的 Web 服务器。它…

模拟器单窗口ip有问题?试试关闭IPV6来解决

目前应该不止雷电9有这个问题了&#xff0c;最早是看到无忧群里在说有这个问题&#xff0c;后面发现很多其他的ip软件也有同样的问题&#xff0c;很多人都遇到&#xff0c;所以做个图文教程在这里&#xff0c;没出问题的也可以设置一下&#xff0c;目前ipv6也还没普及&#xff…

x-cmd pkg | hurl - HTTP 请求处理工具

目录 简介首次用户功能特点竞品和相关作品进一步探索 简介 Hurl 是 HTTP 请求处理工具&#xff0c;支持使用简单的纯文本格式定义的 HTTP 请求。它的用途非常广泛&#xff0c;既可以用于获取数据&#xff0c;也可以用于测试HTTP会话。 它可以链式处理请求&#xff0c;捕获数值…

leetcode-二叉树的后序遍历

145. 二叉树的后序遍历 迭代法 # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right right class Solution:def postorderTraversal(s…