【LeetCode题解】2192. 有向无环图中一个节点的所有祖先+1026. 节点与其祖先之间的最大差值

文章目录

    • [2192. 有向无环图中一个节点的所有祖先](https://leetcode.cn/problems/all-ancestors-of-a-node-in-a-directed-acyclic-graph/)
          • 思路:BFS+记忆化搜索
            • 代码:
          • 思路:逆向DFS
          • 代码:
    • [1026. 节点与其祖先之间的最大差值](https://leetcode.cn/problems/maximum-difference-between-node-and-ancestor/)
        • 思路:DFS
        • 代码:


2192. 有向无环图中一个节点的所有祖先

在这里插入图片描述

在这里插入图片描述

思路:BFS+记忆化搜索

1.遍历二维数组,构建邻接表g。统计每个结点的后续结点

2.g[i]表示结点i的所有后续结点

3.从小到大开始枚举i,i作为祖先结点

4.使用bfs搜索结点i的所有后续结点

5.布尔数组进行标记,避免重复统计

6.将枚举的结点i,添加到它的所有后续结点的祖先列表中

代码:
//2192. 有向无环图中一个节点的所有祖先 BFSprivate int n;private List<Integer>[] g;private List<List<Integer>> ans;public List<List<Integer>> getAncestors(int n, int[][] edges) {g = new List[n];this.n = n;Arrays.setAll(g,i->new ArrayList<>());for (int[]x:edges) {//遍历二维数组,构建邻接表gg[x[0]].add(x[1]);//g[i]表示结点i的所有后续结点}ans = new ArrayList<>();for (int i = 0; i < n; i++) {ans.add(new ArrayList<>());}for (int i = 0; i < n; i++) {//从小到大开始枚举i,作为祖先结点bfs(i);//使用bfs搜索结点i的所有后续结点//然后把结点i,添加进它后续结点的祖先列表}return ans;}private void bfs(int s){Deque<Integer>deque = new ArrayDeque<>();deque.offer(s);boolean[] vis = new boolean[n];vis[s] = true;//进行标记,避免重复while (!deque.isEmpty()){int i = deque.poll();for (int j:g[i]) {if (!vis[j]){vis[j] = true;deque.offer(j);ans.get(j).add(s);}}}}
思路:逆向DFS

1.将有向边进行翻转。

2.从i出发,能访问到的就是i的祖先

3.用数组标记避免重复访问

代码:
    public List<List<Integer>> getAncestors(int n, int[][] edges) {List<Integer>g[] = new ArrayList[n];Arrays.setAll(g,i->new ArrayList<>());for (int[]x:edges) {g[x[1]].add(x[0]);//反向建图//g[i]统计的是每个结点的祖先结点}List<List<Integer>> ans = new ArrayList<>();for (int i = 0; i < n; i++) {ans.add(new ArrayList<>());}boolean[]vis = new boolean[n];for (int i = 0; i < n; i++) {Arrays.fill(vis,false);//每次遍历进行重置dfsA(i,g,vis);vis[i] = false;//祖先结点不含本身for (int j = 0; j < n; j++) {if (vis[j]){ans.get(i).add(j);}}}return ans;}private void dfsA(int x,List<Integer>[]g,boolean[]vis){vis[x] = true;//标记,避免重复统计for (int i:g[x]) {if (!vis[i]){dfsA(i,g,vis);}}}

1026. 节点与其祖先之间的最大差值

在这里插入图片描述

思路:DFS

1.进行深度优先遍历

2.每次都要维护当前结点与祖先结点最小值和最大值的差值

3.每次求出差值后,进行比较,更新最大差值

代码:
    private int num;public int maxAncestorDiff(TreeNode root) {dfsMax(root,root.val,root.val);//将root的值暂时为最大值和最小值return num;}private void dfsMax(TreeNode root ,int max,int min){if (root==null){//结点为空直接返回return ;}int x =Math.max(Math.abs(min-root.val),Math.abs(max-root.val));//求当前结点与祖先结点最小值和最大值的差值num = Math.max(x,num);//更新答案min = Math.min(min,root.val);//维护当前的最小值max = Math.max(max,root.val);//维护当前的最大值dfsMax(root.left,max,min);//在左树找dfsMax(root.right,max,min);//在右树找}

点击移步博客主页,欢迎光临~

偷cyk的图

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

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

相关文章

在MacOS上安装Homebrew:初学者指南

简介&#xff1a; 如果您是MacOS的新手或者不了解Homebrew是什么&#xff0c;那么本文是给您准备的。Homebrew是一个MacOS上的包管理器&#xff0c;它可以让您在几个简单的步骤中安装和管理数千个软件包。在本文中&#xff0c;我们将向您介绍如何在MacOS上安装Homebrew&#x…

为什么说AI的尽头是生物制药?

AI的尽头究竟是什么&#xff1f;有投资者说是光伏&#xff0c;也有投资者说是电力&#xff0c;而英伟达给出的答案则是生物制药。 在英伟达2023年投资版图中&#xff0c;除AI产业根基算法与基础建设外&#xff0c;生物制药是其重点布局的核心赛道。英伟达医疗保健副总裁Kimber…

FastEI论文阅读

前言 研究FastEI&#xff08;Ultra-fast and accurate electron ionization mass spectrum matching for compound identification with million-scale in-silico library&#xff09;有很长时间了&#xff0c;现在来总结一下&#xff0c;梳理一下认知。PS&#xff1a;为什么要…

【LeetCode: 21. 合并两个有序链表 + 链表】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

组件循环依赖问题

场景&#xff1a; a组件 引入 b组件 b组件 引入 a组件 a组件 import B from ./b console.log(A组件&#xff0c;,B) export default Ab组件 import A from ./a console.log(B组件&#xff0c;,A) export default B输出结果&#xff1a; B组件&#xff0c;undefined A组件&am…

axios快速入门

一、环境配置 1.1概述 上古浏览器页面在向服务器请求数据时&#xff0c;因为返回的是整个页面的数据&#xff0c;页面都会强制刷新一下&#xff0c;这对于用户来讲并不是很友好。并且我们只是需要修改页面的部分数据&#xff0c;但是从服务器端发送的却是整个页面的数据&#…

搭建爬虫代理服务器:使用云服务器

1.原理 代理服务器的作用是代替客户端向目标服务器发送请求&#xff0c;然后将目标服务器的响应返回给客户端。在网络中&#xff0c;代理服务器可以用来隐藏客户端的真实 IP 地址&#xff0c;或者用于访问某些受限制的内容&#xff0c;或者实现缓存、安全策略等功能。 在这个…

攻防世界 Broadcast 题目解析

Broadcast 一&#xff1a;题目 二&#xff1a;解析 将压缩包解压&#xff0c;得到如上图所示&#xff0c;打开task.py&#xff0c;之后得到flag 这个有点简单了&#xff0c;不要被解压后文件太多所迷惑。

InnoDB中的索引方案

文章目录 InnoDB中的索引方案 InnoDB支持多种类型的索引&#xff0c;包括B-tree索引、全文索引、哈希索引等。B-tree索引是InnoDB存储引擎的默认索引类型&#xff0c;适用于所有的数据类型&#xff0c;包括字符串、数字和日期等。 以下是创建InnoDB表及其B-tree索引的示例代码…

python+ opencv(Mat)——笔记

opencv中用Mat数据类型来表示图片&#xff1b; python中将mat转化为numpy的ndarray&#xff1b;type&#xff08;img&#xff09;numpy.ndarray; Mat的属性: rows&#xff1a;表示矩阵的行数。cols&#xff1a;表示矩阵的列数。size&#xff1a;表示矩阵的尺寸&#xff0c;即…

VBA数据库解决方案第九讲:把数据库的内容在工作表中显示

《VBA数据库解决方案》教程&#xff08;版权10090845&#xff09;是我推出的第二套教程&#xff0c;目前已经是第二版修订了。这套教程定位于中级&#xff0c;是学完字典后的另一个专题讲解。数据库是数据处理的利器&#xff0c;教程中详细介绍了利用ADO连接ACCDB和EXCEL的方法…

2024年阿里云4核8G服务器多少钱一年?4C8G服务器955元

阿里云服务器4核8G租用优惠价格955元一年&#xff0c;配置为云服务器ECS通用算力型u1实例4核8G配置、ESSD Entry盘20G-40G、1M-3M带宽&#xff0c;实例规格为ecs.u1-c1m2.xlarge&#xff0c;阿里云优惠活动 yunfuwuqiba.com/go/aliyun 活动链接打开如下图&#xff1a; 阿里云4核…

SpringBoot整合Quartz报错

SpringBoot整合Quartz报错 报错信息如下&#xff1a; Unable to detect database type原因&#xff1a;刚开始为了生成quartz的表&#xff0c;配置的是always&#xff0c;后面再次启动没有修改 spring:quartz:jdbc:initialize-schema: always#每次启动时创建quartz表解决办法…

【数据结构】ArrayList详解

目录 前言 1. 线性表 2. 顺序表 3. ArrayList的介绍和使用 3.1 语法格式 3.2 添加元素 3.3 删除元素 3.4 截取部分arrayList 3.5 其他方法 4. ArrayList的遍历 5.ArrayList的扩容机制 6. ArrayList的优缺点 结语 前言 在集合框架中&#xff0c;ArrayList就是一个…

spring boot学习第十六篇:配置多数据源

1、代码参考&#xff1a; dynamic-ds/spring-boot-dynamic-ds at main veminhe/dynamic-ds GitHub 2、验证 2.1调用POST接口http://localhost:8081/hmblogs/blog/addBlog 2.2改动数据源为BJ 然后调用接口添加数据 然后查看ds0库的博客数据

【最新可用】Claude国内镜像,可上传图片,可用Claude3全系模型(包括Pro版本的Opus)!亲测比GPT好用!

亲测可用&#xff0c;镜像地址&#xff1a;Claude 3 镜像 使用方法 访问镜像&#xff1a;Claude 3 镜像 2. 点击设置&#xff0c;配置授权码&#xff0c;关闭设置。这里免费赠送一个体验版的授权码 sk-SZcJyvx3RXRID624E2D3795578Df44C7Af03F2909a8f5eA0 即可发起对话啦&…

Android Studio学习9——使用Logcat打印日志

在Android开发中&#xff0c;Logcat是一个工具&#xff0c;它允许开发者查看设备或模拟器的日志信息。开发者可以使用Log类来打印日志信息&#xff0c;这对于调试和错误排查非常有帮助。 v 或 verbose: 最低等级&#xff0c;显示所有消息。d 或 debug: 用于调试消息。i 或 info…

网络安全介绍

网络安全是指网络系统的硬件、软件及其系统中的数据受到保护&#xff0c;不因偶然的或者恶意的原因而遭受到破坏、更改、泄露&#xff0c;系统能够连续可靠正常地运行&#xff0c;网络服务不中断。以下是一些网络安全相关的方面&#xff1a; 首先&#xff0c;随着科学技术的进…

工业物联网中的区块链技术应用

工业物联网&#xff08;Industrial Internet of Things, IIoT&#xff09;与区块链技术的结合&#xff0c;为工业自动化和信息化带来了新的可能性。这种融合可以提高工业系统的安全性、透明度、效率和可追溯性。以下是工业物联网中区块链技术应用的几个关键方面&#xff1a; 数…

深入浅出 -- 系统架构之负载均衡Nginx动静分离

一、Nginx动静分离 动静分离应该是听的次数较多的性能优化方案&#xff0c;那先思考一个问题&#xff1a;为什么需要做动静分离呢&#xff1f;它带来的好处是什么&#xff1f; 其实这个问题也并不难回答&#xff0c;当你搞懂了网站的本质后&#xff0c;自然就理解了动静分离的重…