【数据结构与算法 | 搜索二叉树篇 力扣篇】力扣530, 501

1. 力扣530:二叉搜索树的最小绝对差

1.1 题目:

给你一个二叉搜索树的根节点 root ,返回 树中任意两不同节点值之间的最小差值 。

差值是一个正数,其数值等于两值之差的绝对值。

示例 1:

52bef180bb264050ac1c0b2c5b2a238f.jpeg

输入:root = [4,2,6,1,3]
输出:1

示例 2:

6ba3600e2a954db483519ec50eae41d2.jpeg

输入:root = [1,0,48,null,null,12,49]
输出:1

提示:

  • 树中节点的数目范围是 [2, 104]
  • 0 <= Node.val <= 105

1.2 思路

题目虽然说求任意两个不同的节点的差值,但很容易发现,排序以后,只需要比较两个相邻节点的差值即可。

1.3 题解:

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {// 用列表记录二叉树节点的值List<Integer> list = new ArrayList<>();public int getMinimumDifference(TreeNode root) {recursion(root);// 调用库方法排序Collections.sort(list);// 因为由题,该二叉树最少两个节点int targrt = list.get(0) - list.get(1);if(targrt < 0) {targrt = -targrt;}// 排序以后只需要比较两个相邻的元素的差值for(int i = 0; i < list.size() - 1; i++) {int diff = list.get(i) - list.get(i + 1);if(diff < 0) {diff = -diff;}targrt = targrt > diff ? diff : targrt;}return targrt;}private void recursion(TreeNode node) {if(node == null) {return;}list.add(node.val);recursion(node.left);recursion(node.right);}
}

2. 力扣501:二叉搜索树中的众数

2.1 题目:

给你一个含重复值的二叉搜索树(BST)的根节点 root ,找出并返回 BST 中的所有 众数(即,出现频率最高的元素)。

如果树中有不止一个众数,可以按 任意顺序 返回。

假定 BST 满足如下定义:

  • 结点左子树中所含节点的值 小于等于 当前节点的值
  • 结点右子树中所含节点的值 大于等于 当前节点的值
  • 左子树和右子树都是二叉搜索树

示例 1:

输入:root = [1,null,2,2]
输出:[2]

示例 2:

输入:root = [0]
输出:[0]

提示:

  • 树中节点的数目在范围 [1, 104] 内
  • -105 <= Node.val <= 105

进阶:你可以不使用额外的空间吗?(假设由递归产生的隐式调用栈的开销不被计算在内)

2.2 思路:

使用到了哈希表,动态数组和递归。哈希表的键用来存储节点的值,值用来存储节点值的个数。用max_num来判断是否需要向列表中添加元素。最后列表中剩下来的元素就是最后要返回的元素。但方法要求返回一个数组,那么就简单转换以下就好了。

个人感觉还可以用计数排序来解决这个问题,应该会更加的简洁和方便。

2.3 题解
 

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {HashMap<Integer, Integer> hashmap = new HashMap<>();// 哈希表用键存储节点的值,用值来存储节点的值出现的次数int max_num;//该变量表示众数List<Integer> list = new ArrayList<>();public int[] findMode(TreeNode root) {recursion(root);int[] target = new int[list.size()];for(int i = 0; i < list.size();i++){target[i] = list.get(i);}return target;}private void recursion(TreeNode node) {if(node == null) {return;}// 记录操作之前的max_num,用于后续比较int old_max_num = max_num;if(!hashmap.containsKey(node.val)){hashmap.put(node.val, 1);max_num = Integer.max(max_num, 1);} else {hashmap.put(node.val, hashmap.get(node.val) + 1);max_num = Integer.max(max_num, hashmap.get(node.val));}//看max_num做没做出更新,如果做出更新,则清空列表// 如果没做出更新,但是该节点的值的个数与最大值一样,则加入到列表if(old_max_num != max_num){list.clear();list.add(node.val);} else if(max_num == hashmap.get(node.val)){list.add(node.val);}recursion(node.left);recursion(node.right);}
}

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

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

相关文章

C# 调用百度API批量识别发票,并存到EXCEL

C# 调用百度API批量识别发票&#xff0c;并存到EXCEL ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/f406f2185184456daa9ba7829c26138d.png#pic_center)using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Thr…

BUUCTF—[BJDCTF2020]The mystery of ip

题解 打开环境点击上面的flag可以看到这个IP页面。 抓个包看看有啥东西无&#xff0c;可以看到在返回包有IP。 看到IP就想到X-Forwarded-For这个玩意&#xff0c;我们用X-Forwarded-For随便添加个IP看看。可以看到返回的IP内容变成了123。 X-Forwarded-For:123 推测它会输出我…

Java项目怎么从零部署到Linux服务器上?

目录 一.Java环境&#xff08;JDK&#xff09;安装 二.数据库&#xff08;MySQL&#xff09;安装 三.部署上线 ▐ 部署Jar包 ▐ 运行程序 ▐ 开放端口 一个Java项目首先需要一个支持它编译的Java环境&#xff0c;因此首先要保证服务器上安装的有相应的JDK 一.Java环境&a…

JWT与shiro结合实现认证

随着微服务架构的普及和前后端分离的趋势&#xff0c;越来越多的项目开始采用无状态的认证机制&#xff0c;其中JSON Web Token&#xff08;JWT&#xff09;成为了一种流行的选择。与此同时&#xff0c;Apache Shiro作为一个强大且易于使用的Java安全框架&#xff0c;仍然被广泛…

Windows电脑获取目录及子目录结构及包含文件名的命令

在Windows 11中&#xff0c;你可以使用多种方式来获取当前目录及其子目录的结构&#xff0c;包括文件名。最直接且广泛使用的方法是使用命令行工具&#xff0c;如cmd&#xff08;命令提示符&#xff09;或PowerShell。下面是两种不同方式来实现这一需求的示例。 使用cmd&#…

负载均衡 Ribbon 与 Fegin 远程调用原理

文章目录 一、什么是负载均衡二、Ribbon 负载均衡2.1 Ribbon 使用2.2 Ribbon 实现原理 (★)2.3 Ribbon 负载均衡算法 三、Feign 远程调用3.1 Feign 简述3.2 Feign 的集成3.3 Feign 实现原理 (★) 一、什么是负载均衡 《服务治理&#xff1a;Nacos 注册中心》 末尾提到了负载均…

Vue2和Vue3项目创建的区别和 element ui 和element plus的导入方式

文章目录 创建项目Vue2Vue3 Vue2项目机构Vue 2 Element UI VUE3项目结构Vue 3 Element Plus 创建项目 Vue2 Vue CLI 3 及之前版本&#xff1a; 使用 vue-cli 创建项目&#xff1a; npm install -g vue/cli vue create my-project-vue2 cd my-project-vue2Vue3 Vue CLI 4…

第二十篇——行军篇:别指望外援,好好培养亲兵

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 微观层面&#xff0c;从驯服的视角&#xff0c;我们可以洞察到人性中非常…

一篇文章深入了解Oracle常用命令

1. 数据库 1.1. 数据库启动 & 关闭 –启动数据库 SQL> startup nomount; SQL> alter database mount; SQL> alter database open;–关闭数据库 SQL> shutdown immediate&#xff1b;1.2. 连接数据库 –登录普通用户 SQL>sqlplus 用户名/密码实例名–…

2024.9.4

继续该题&#xff0c;除了实在改不来的&#xff0c;基本快改完了 #2316. 飓风&#xff08;hurricane&#xff09; #1575. 【EOJ Long Round】本质不同GCD 被hack了重新写一下&#xff0c;乱搞复杂度大了点 #2303. 最小子列&#xff08;subseq&#xff09; 先从没有限制考虑起&a…

leveldb源码剖析(二)——LSM Tree

LSM Tree LSM Tree&#xff1a;Log-Structured Merge Tree&#xff0c;日志结构合并树。是一种频繁写性能很高的数据结构。 LSM Tree将写入操作与合并操作分离&#xff0c;数据首先写入磁盘中的日志文件&#xff08;WAL&#xff09;&#xff0c;随后写入内存缓存&#xff0c;…

UDP英译汉网络词典

这里我们用UDP实现一个简单的英译汉小词典。我们还是仿照前一篇的UDP编程&#xff0c;将各自的组件封装起来&#xff0c;实现高内聚低耦合。 一. 字典翻译功能实现 首先我们将我们的字典知识库放在txt文本中。 apple: 苹果 banana: 香蕉 cat: 猫 dog: 狗 book: 书 pen: 笔 ha…

云计算之ECS

目录 一、ECS云服务器 1.1 ECS的构成 1.2 ECS的实例规格 1.3 镜像 1.4 磁盘 1.5 安全组 1.6 网络 1.7 产品结构 二、块存储介绍 2.1 快存储定义 2.2 块存储性能指标 2.3 快存储常用操作-云盘扩容 2.4 块存储常见问题 三、快照介绍 3.1 快照定义 3.2 快照常见问题…

flume 使用 exec 采集容器日志,转储磁盘

flume 使用 exec 采集容器日志&#xff0c;转储磁盘 在该场景下&#xff0c;docker 服务为superset&#xff0c;flume 的sources 选择 exec &#xff0c; sinks选择 file roll 。 任务配置 具体配置文件如下&#xff1a; #simple.conf: A single-node Flume configuration#…

随笔(1)将 CSV 文件导入 MySQL 时出现中文乱码问题解决方案

将 CSV 文件导入 MySQL 时出现中文乱码问题解决方案 一、检查 CSV 文件编码 确认 CSV 文件的编码格式。常见的编码有 UTF-8、GBK 等。你可以使用文本编辑器&#xff08;如 Notepad&#xff09;打开 CSV 文件&#xff0c;查看其编码格式。如果编码格式不是 UTF-8&#xff0c;可…

GPT-4o mini轻量级大模型颠覆AI的未来

GPT-4o mini发布&#xff0c;轻量级大模型如何颠覆AI的未来&#xff1f; 引言 随着人工智能技术的飞速发展&#xff0c;大型AI模型的发布已成常态。然而&#xff0c;庞大的计算资源和存储空间限制了它们在广泛场景中的应用。为满足市场需求&#xff0c;轻量级大模型应运而生&a…

TOMATO靶机漏洞复现

步骤一&#xff0c;我们来到tomato页面 什么也弄不了只有一番茄图片 弱口令不行&#xff0c;xxs也不行&#xff0c;xxe还是不行 我们来使用kali来操作... 步骤二&#xff0c;使用dirb再扫一下, dirb http://172.16.1.133 1.发现这个文件可以访问.我们来访问一下 /antibot_i…

【课程学习】信号检测与估计

文章目录 3.7-CRB延展到向量的形式3.8-参数变换形式的CRB CRB for transformation, pp45-463.9-高斯分布 CRLB for the General Gaussian Case3.7-CRB延展到向量的形式 0904 向量和变换形式的CRLB形式 估计参数真实值 θ \theta θ,估计值 θ ^ \hat \theta θ^ 与信号与系统…

C# NX二次开发-获取对象名称

UG软件是所有带标签对象都能设置名称和属性&#xff1a; 代码&#xff1a; theUf.Obj.AskName(body.Tag,out string name);name.NxListing(); 免责声明&#xff1a; 只用于参考&#xff0c;如果有什么问题不要找我呀。

NewStringUTF和GetStringUTFChars 的差别

NewStringUTF 和 GetStringUTFChars 是 JNI&#xff08;Java Native Interface&#xff09;提供的两个函数&#xff0c;它们都用于在 JNI 代码中处理字符串&#xff0c;但用途和行为有所不同&#xff1a; NewStringUTF 功能&#xff1a;NewStringUTF 用于在 JNI 代码中创建一个…