【LeetCode: 173. 二叉搜索树迭代器 + dfs + 二叉搜索树】

在这里插入图片描述

🚀 算法题 🚀

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域优质创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

🚀 算法题 🚀

在这里插入图片描述

在这里插入图片描述

🍔 目录

    • 🚩 题目链接
    • ⛲ 题目描述
    • 🌟 求解思路&实现代码&运行结果
      • ⚡ dfs + 二叉搜索树
        • 🥦 求解思路
        • 🥦 实现代码
        • 🥦 运行结果
    • 💬 共勉

🚩 题目链接

  • 173. 二叉搜索树迭代器

⛲ 题目描述

实现一个二叉搜索树迭代器类BSTIterator ,表示一个按中序遍历二叉搜索树(BST)的迭代器:
BSTIterator(TreeNode root) 初始化 BSTIterator 类的一个对象。BST 的根节点 root 会作为构造函数的一部分给出。指针应初始化为一个不存在于 BST 中的数字,且该数字小于 BST 中的任何元素。
boolean hasNext() 如果向指针右侧遍历存在数字,则返回 true ;否则返回 false 。
int next()将指针向右移动,然后返回指针处的数字。
注意,指针初始化为一个不存在于 BST 中的数字,所以对 next() 的首次调用将返回 BST 中的最小元素。

你可以假设 next() 调用总是有效的,也就是说,当调用 next() 时,BST 的中序遍历中至少存在一个下一个数字。

示例:
在这里插入图片描述

输入
[“BSTIterator”, “next”, “next”, “hasNext”, “next”, “hasNext”, “next”, “hasNext”, “next”, “hasNext”]
[[[7, 3, 15, null, null, 9, 20]], [], [], [], [], [], [], [], [], []]
输出
[null, 3, 7, true, 9, true, 15, true, 20, false]

解释
BSTIterator bSTIterator = new BSTIterator([7, 3, 15, null, null, 9, 20]);
bSTIterator.next(); // 返回 3
bSTIterator.next(); // 返回 7
bSTIterator.hasNext(); // 返回 True
bSTIterator.next(); // 返回 9
bSTIterator.hasNext(); // 返回 True
bSTIterator.next(); // 返回 15
bSTIterator.hasNext(); // 返回 True
bSTIterator.next(); // 返回 20
bSTIterator.hasNext(); // 返回 False

提示:

树中节点的数目在范围 [1, 105] 内
0 <= Node.val <= 106
最多调用 105 次 hasNext 和 next 操作

🌟 求解思路&实现代码&运行结果


⚡ dfs + 二叉搜索树

🥦 求解思路
  1. 通过dfs对二叉搜索树做中序遍历,获取的结果保存在集合中。最后,通过获得到的集合来实现next()和hasnext()函数。
  2. next()函数:每次调用next()函数,通过集合来获取位置的元素,每次调用通过维护一个idx来实现。
  3. hasnext()函数:此时如果向指针右侧遍历存在数字,返回true,否则,返回false。通过 idx < arr.size() 来实现。
  4. 有了基本的思路,接下来我们就来通过代码来实现一下。
🥦 实现代码
class BSTIterator {private int idx = 0;private List<Integer> arr = new ArrayList<Integer>();public BSTIterator(TreeNode root) {dfs(root);}public int next() {return arr.get(idx++);}public boolean hasNext() {return idx < arr.size();}private void dfs(TreeNode root) {if (root == null) {return;}dfs(root.left);arr.add(root.val);dfs(root.right);}
}
🥦 运行结果

在这里插入图片描述


💬 共勉

最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉!

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

电脑数据安全新利器:自动备份文件的重要性与实用方案

一、数据安全的守护神&#xff1a;自动备份文件的重要性 在数字化时代&#xff0c;电脑中的文件承载着我们的工作成果、个人回忆以及众多重要信息。然而&#xff0c;数据丢失的风险无处不在&#xff0c;无论是硬件故障、软件崩溃&#xff0c;还是恶意软件的攻击&#xff0c;都…

Python计算机二级选择易错题(一)

题目来源&#xff1a;python计算机二级真题&#xff08;选择题&#xff09; - 知乎 选择题第08&#xff0c;09套

力扣刷题Days22-49.字母异位词(js)

目录 1&#xff0c;题目 2&#xff0c;代码 2.1利用数组排序作为键名 2.2计数实现 3&#xff0c;学习与总结 1&#xff0c;题目 给你一个字符串数组&#xff0c;请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到…

【WSL】Windows11 迁移 Linux 子系统到非系统盘 (如D 盘),减少系统盘占用

1、安装 安装见官方文档进行安装&#xff0c;参考 https://learn.microsoft.com/zh-cn/windows/wsl/install wsl --install Ubuntu-20.04安装时&#xff0c;若出现 0x80370… 错误&#xff0c;下载下面依赖&#xff0c;再进行上述安装 https://wslstorestorage.blob.core.w…

虚拟化技术

前言 大家好我是jiantaoyab&#xff0c;这是我所总结作为学习的笔记第十八篇&#xff0c;在这里分享给大家&#xff0c;这篇文章讲虚拟技术就是大家平时用到的云服务器是什么。 虚拟机技术变迁 虚拟机&#xff08;Virtual Machine&#xff09;技术&#xff0c;其实就是指在现…

关于Oracle Primavera P6 v23.12新增的特殊功能

​​​​​​​ 本文将介绍Oracle Primavera P6 最新发行版v23.12 中有新增哪些特色功能 1.角色限制计算的细化 如果选择显示根据主要资源限制计算的角色限制&#xff0c;你可以选择在“用户首选项”的“资源分析”选项卡上仅使用 P6 Professional 中的活动资源来计算限制。…

企业常用管理制度清单

制度类别 细分项目 制度名称 企业文化建设管理制度 规划与日常管理制度 企业文化建设规划与实施细则 企业文化建设管理办法 员工行为规范 企业文化培训管理流程图 企业文化宣贯队伍管理办法 企业文化评价与考核制度 企业文化建设评价与考核制度 企业文化建设…

Spring-Gateway服务网关

一、网关介绍 1. 为什么需要网关 Gateway网关是我们服务的守门神&#xff0c;所有微服务的统一入口。 网关的核心功能特性&#xff1a; 请求路由 权限控制 限流 架构图&#xff1a; 权限控制&#xff1a;网关作为微服务入口&#xff0c;需要校验用户是是否有请求资格&am…

高端嵌入式底层技术揭秘:《ARM汇编与逆向工程》

ARM架构简介 与传统的CISC&#xff08;Complex Instruction Set Computer&#xff0c;复杂指令集计算机&#xff09;架构相比&#xff0c;Arm架构的指令集更加简洁明了&#xff0c;指令执行效率更高&#xff0c;能够在更低的功耗下完成同样的计算任务&#xff0c;因此在低功耗…

el-dialog弹框遮罩层问题

先看一下出现的bug&#xff0c;点击按钮出现弹框的时候&#xff0c;遮罩层出现在弹框上层&#xff0c;不知道是那个同事写的全局样式影响的&#xff0c;这个时候我们需要在el-dialog标签上添加一个属性就行 :modal-append-to-body“false” 下图是出现的问题&#xff0c;遮罩层…

[论文笔记] Dual-Channel Span for Aspect Sentiment Triplet Extraction

一种利用句法依赖和词性相关性信息来过滤噪声&#xff08;无关跨度&#xff09;的基于span方法。 会议EMNLP 2023作者Pan Li, Ping Li, Kai Zhang团队Southwest Petroleum University论文地址https://aclanthology.org/2023.emnlp-main.17/代码地址https://github.com/bert-ply…

MSF融合流程

1. 添加重力约束 重力约束是在在车体系的方向是&#xff08;0&#xff0c;0&#xff0c;1&#xff09;&#xff0c;添加时1&#xff09;如果已知车辆在水平方向运动&#xff0c;添加平面约束&#xff1b;2&#xff09;如果已知车辆静止&#xff08;判断IMU加速度计和陀螺仪的n…

【基础】连续数的和 c++

描述 给出两个整数n和k&#xff0c;&#xff08;2≤n≤70000,1≤k≤n&#xff09;&#xff0c;求出1,2,3,…,n中连续k个数的和&#xff0c;并计算出和为平方数的个数。 例如n10,k3。在1,2,…,10中&#xff0c;连续3个数的和有 1236 2349 34512 45615 56718 67821 78924 891027…

reflectasm java 高性能反射工具

reflectasm java 高性能反射工具 大佬文章 官网示例 maven 引入 <dependency><groupId>com.esotericsoftware</groupId><artifactId>reflectasm</artifactId><version>1.11.9</version> </dependency>实体类 public class U…

MySQL数据自动同步到Es

Logstash 测试数据准备 DROP DATABASE IF EXISTS es;CREATE DATABASE es DEFAULT CHARACTER SET utf8;USE es;CREATE TABLE book (id INT NOT NULL,title VARCHAR(20),author VARCHAR(20),price DECIMAL(6,2),PRIMARY KEY(id) );DROP PROCEDURE IF EXISTS batchInsertBook;DELI…

【Java基础知识总结 | 第四篇】Java基础重要知识(面试题)

文章目录 4.Java基础重要知识&#xff08;面试题&#xff09;4.1基本数据类型4.1.1 八种基本数据类型4.1.2 基本类型和包装类型的区别4.1.3包装类型的缓存机制4.1.4自动装箱和拆箱&#xff1f;原理&#xff1f;&#xff08;1&#xff09;定义&#xff08;2&#xff09;原理 4.2…

使用 BPF 监控 Kubernetes 集群(k8s BPF 工具 kubectl-trace认知

写在前面 学习中遇到&#xff0c;整理分享&#xff0c;博文内容涉及&#xff1a;kubectl-trace 安装&#xff0c;在节点&#xff0c;容器中如何使用需要注意的问题&#xff1a;job 闪完成&#xff0c;一直 Pending 状态解决理解不足小伙伴帮忙指正 不必太纠结于当下&#xff0c…

ROS使用catkin_make编译单个功能包和所有功能包

编译功能包&#xff1a; catkin_make -DCATKIN_WHITELIST_PACKAGES"需要单独编译的包名"但是如再次使用catkin_make编译所有功能包时会出现只编译上次设置的单独功能包&#xff0c;如果想要再次使用catkin_make编译所有功能包&#xff0c;需要执行&#xff1a; cat…

c++异构计算获取计算进度

异步运行任务&#xff0c;并定期检查任务是否已完成。如果没有&#xff0c;您希望打印出任务的进度。但是&#xff0c;您提供的代码存在一些问题&#xff1a; 1。“TaskRun”类未在您提供的代码段中定义。请确保其定义正确&#xff0c;并且“run”方法是“TaskRun”的成员函数…

springboot项目讲解

技术栈 vue(前端) springboot(后端主框架) mybatis&#xff08;ORM&#xff0c;用于后端和数据库的映射&#xff0c;即java对象转换成表&#xff09; mysql (关系型数据库) 顶层结构 .idea&#xff1a; idea缓存文件(不需要管) src&#xff1a;代码核心文件夹 —main&#xf…