【LeetCode-面试经典150题-day25】

2023-09-17 16:27:16

目录

530.二叉搜索树的最小绝对差

 230.二叉搜索树中第K小的元素

 98.验证二叉搜索树


 

530.二叉搜索树的最小绝对差

题意:

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

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

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

【输入样例】root = [4,2,6,1,3]

【输出样例】1

解题思路:

二叉搜索树的特点,左子树的所有值都比根节点小,右子树的所有值都比根节点大;

要找最小差值,其选择一定为相邻两个元素之差的最小值。

通过遍历树来计算差值,并将结果保存起来,边遍历边比较。

遍历方法使用中序遍历,因为中序遍历出来的结果是有序的。

class Solution {
    int ans,pre;//Pre保存前驱节点的值
    public int getMinimumDifference(TreeNode root) {
        ans = Integer.MAX_VALUE;
        pre = -1;//提示中说明节点值的范围是[0,105],所以初始化为-1
        midOrder(root);
        return ans;      
    }

    void midOrder(TreeNode root){
        if(root == null){
            return;
        }
        midOrder(root.left);
        if(pre == -1){
            pre = root.val;
        }else{
            ans = Math.min(ans, root.val - pre);
            pre = root.val;
        }
        midOrder(root.right);
    }
}

时间: 击败了100.00%

内存: 击败了29.78%

 230.二叉搜索树中第K小的元素

题意:

给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 个最小元素(从 1 开始计数)。

提示:

  • 树中的节点数为 n 。
  • 1 <= k <= n <= 104
  • 0 <= Node.val <= 104

【输入样例】root = [3,1,4,null,2], k = 1

【输出样例】1

解题思路:

中序遍历找到第k个数就可以了。

为了避免遍历完所有节点,不使用递归搜索,而是使用迭代搜索,借助栈

class Solution {
    public int kthSmallest(TreeNode root, int k) {
        Deque<TreeNode> stack = new ArrayDeque<TreeNode>();
        while(root != null || !stack.isEmpty()){
            while(root != null){
                stack.push(root);//先把根存进去,然后先找左子树
                root = root.left;//左 根 右,持续进栈根节点,直到找到最左的节点
            }
            //循环结束条件是root为空,证明上一个root没有左节点,出栈
            root = stack.pop();
            --k;//遍历到一个数减一次
            if(k == 0){
                break;
            }
            root = root.right;//往节点右子树找了
        }
        return root.val;
    }
}

时间: 击败了24.31%

内存: 击败了75.46%

 98.验证二叉搜索树

题意:

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

  • 节点的左子树只包含 小于 当前节点的数。
  • 节点的右子树只包含 大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

提示:

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

【输入样例】root = [2,1,3]

【输出样例】true

解题思路:

跟上一题一样,借助栈进行中序遍历,用pre保存前一节点的值,如果root.val <=pre,则表示不是二叉搜索树。

class Solution {
    public boolean isValidBST(TreeNode root) {
        double pre = -Double.MAX_VALUE;;
        Deque<TreeNode> stack = new ArrayDeque<TreeNode>();
        while(root != null || !stack.isEmpty()){
            while(root != null){
                stack.push(root);
                root = root.left;
            }
            root = stack.pop();
            if(root.val <= pre){//=也不符合二叉搜索树的要求
                return false;//不满足
            }
            pre = root.val;
            root = root.right;
        }
        return true;
    }
}

时间: 击败了18.62%

内存: 击败了49.12%

更多推荐

zoneinfo

在Linux系统中,zoneinfo是一个包含了世界各地时区信息的目录,通常位于/usr/share/zoneinfo。这个目录下的子目录和文件名对应了各个时区的名称。例如,/usr/share/zoneinfo/America/Los_Angeles文件就包含了美国洛杉矶的时区信息。你可以通过以下步骤来使用zonei

阿里云产品试用系列-云桌面电脑

无影云电脑(WUYINGWorkspace),是一种易用、安全、高效的云上桌面服务。它支持快速便捷的桌面环境创建、部署、统一管控与运维。无需前期传统硬件投资,帮您快速构建安全、高性能、低成本的企业桌面办公体系。可广泛应用于具有高数据安全管控、高性能计算等要求的安全办公、金融、设计、影视、教育等领域。如上所示,在阿里云官

使用 vue + vant 开发移动端网页

使用vue+vant开发移动端移动端开发的时候我们通常需要进行适配,比如设计图宽度是750px我们为了适应不同的设备,需要将我们设计图上的px转为视口单位vw这里我们采用postcss-px-to-viewport安装:npminstallpostcss-px-to-viewportvant-S新建postcss.co

Rasa:使用大语言模型进行意图分类

Rasa:使用大语言模型进行意图分类在Rasa的最新版本(3.x)中,引入了一种新的意图分类方法,即使用大型语言模型(LLM)和一种称为检索增强生成(RAG)的方法进行意图分类。LLM意图分类器是一种全新的意图分类器,利用大型语言模型(LLM)来对意图进行分类。LLM意图分类器依赖于检索增强生成(RAG)方法,结合了基

爬虫入门基础:深入解析HTTP协议的工作过程

在网络爬虫的学习中,了解HTTP协议的工作过程是非常重要的。HTTP(HypertextTransferProtocol)是一种用于在Web浏览器和服务器之间传输数据的协议,它负责客户端请求和服务器响应之间的通信。本文将详细介绍HTTP协议的工作过程,帮助你深入理解网络爬取的基础知识。让我们一起探索吧!一、HTTP协议

OpenResty使用漏桶算法实现限流

前言其它项目组需要调用接口,添加接口限流,防止项目被狂掉宕机。生产用了openresty,所以在openresty上添加按接口限流,同时,需按照不同接口有不同的限流规则,使用openresty中内置的漏桶算法方式限流。漏桶算法漏桶算法思路简单,水(请求)先进入到漏桶里,漏桶以一定的速度出水,当水流入速度过大会直接溢出,

BENTLY 350015 127610-01数字量输入模块

数字输入功能:BENTLY350015127610-01模块通常用于监测和采集数字输入信号,例如开关状态、传感器状态等。多通道:这些模块通常具有多个输入通道,允许同时监测多个数字输入信号。高精度:BENTLY350015127610-01模块提供高精度的信号采集,以确保准确的数据记录和分析。实时监测:具备实时监测功能,

pdf怎么压缩的小一点?pdf文件压缩方法汇总

在日常生活中,我们常常需要处理大量的PDF文件。有时候,这些PDF文件可能因为内容丰富、结构复杂而体积庞大,给我们的存储和传输带来了不便。那么,如何将这些PDF文件压缩得小一点,以便更方便地使用呢?一、嗨格式压缩大师嗨格式压缩大师是一款专业的文件压缩工具,支持图片、视频和PDF等各类文件的压缩,使用它压缩PDF文件,可

机器学习——pca降维/交叉验证/网格交叉验证

1、pca降维:目的是提升模型训练速度定义:使用方法:给训练数据或者测试数据进行降维处理给训练数据降维给测试数据降维:这里1就要用transform,而不是fit_transform,因为之前训练数据降维时特征已经确定,测试数据提取的特征要和训练数据保持一致。2、交叉验证:目的是保证模型的测试数据和训练数据划分清楚,从

[2023.09.12]: Yew应用开发的第一个hook--use_state

Yew的SSR模式推荐使用function_component组件,并且在function_component中使用hooks。其中,我使用到的第一个hook是use_state。use_state的设计意图与React中的useState非常相似,都是为了保存并修改当前的状态。然而,由于Yew是用Rust语言实现的,

算法leetcode|83. 删除排序链表中的重复元素(rust重拳出击)

文章目录83.删除排序链表中的重复元素:样例1:样例2:提示:分析:题解:rust:go:c++:python:java:83.删除排序链表中的重复元素:给定一个已排序的链表的头head,删除所有重复的元素,使每个元素只出现一次。返回已排序的链表。样例1:输入:head=[1,1,2]输出:[1,2]样例2:输入:he

热文推荐