当前位置: 首页 > news >正文

LC.173 | 二叉搜索树迭代器 | 树 | 中序展开/栈模拟

输入:BST 根节点root,构造BSTIterator

要求:
实现一个按中序遍历输出 BST 的迭代器:

  • next():返回下一个最小值
  • hasNext():是否还有下一个元素

输出:按题意实现类方法(next/hasNext)。


思路:

思路 A:中序遍历“展开成线性表”

核心就是一句话:

BST 中序遍历 = 递增序列
先把整棵树中序遍历一遍,把结果按顺序塞进链表/数组,然后迭代器只是在这个线性结构上移动指针。

  1. 构造时inorder(root),按中序顺序把每个节点值 append 到单链表尾部。
  2. cur指向链表头(第一个最小值)。
  3. next()返回cur->val并前进。
  4. hasNext()cur != nullptr

优点:

  • 写起来直观,next/hasNext都是 O(1)。

缺点:

  • 构造函数要遍历整棵树,时间 O(N)。
  • 额外存了 N 个节点值,空间 O(N)。
  • 题目进阶想要更省空间(典型答案是 O(H))。

思路 B:用栈模拟中序遍历(更优解的核心思想)

迭代器本质是:每次只走到“下一个该访问的中序节点”,不提前把整棵树铺开。

维护一个栈stk

  • 构造时:把root的整条左链压栈(走到最左)。
  • next()
    1. 弹出栈顶x(当前最小)
    2. 如果x有右子树,把x->right的整条左链压栈
    3. 返回x->val
  • hasNext():看栈空不空

复杂度:

  • 思路 A(暴力)

    • 构造:O(N)
    • next/hasNext:O(1)
    • 空间:O(N)
  • 思路 B(栈模拟)

    • 构造:O(H)
    • next:均摊 O(1)(每个节点最多入栈出栈一次)
    • 空间:O(H)

//思路A 暴力classBSTIterator{public:BSTIterator(TreeNode*root){dummy=newListNode(0);tail=dummy;inorder(root);cur=dummy->next;}intnext(){intval=cur->val;cur=cur->next;returnval;}boolhasNext(){returncur!=nullptr;}private:structListNode{intval;ListNode*next;ListNode(intx):val(x),next(nullptr){}};ListNode*dummy;ListNode*tail;ListNode*cur;voidinorder(TreeNode*node){if(node==nullptr)return;inorder(node->left);tail->next=newListNode(node->val);tail=tail->next;inorder(node->right);}};//思路B 栈模拟classBSTIterator{public:BSTIterator(TreeNode*root){pushLeftChain(root);}intnext(){TreeNode*node=st.top();st.pop();intret=node->val;// 下一批候选:node 的右子树的最左链if(node->right){pushLeftChain(node->right);}returnret;}boolhasNext(){return!st.empty();}private:stack<TreeNode*>st;voidpushLeftChain(TreeNode*node){while(node){st.push(node);node=node->left;}}};
http://www.cnnetsun.cn/news/191561.html

相关文章:

  • 【国产 OS 顶流实战】KylinOS V10 等保 2.0 三级合规 + MES 系统国产化迁移全案
  • Java基于springboot+vue的毕业生离校管理系统的设计与实现
  • 【毕业设计】基于springboot的旧物回收商城系统的设计与实现(源码+文档+远程调试,全bao定制等)
  • OpenMV中HOG特征提取全面讲解
  • 8个AI论文生成平台测评,降重与写作功能深度解析
  • 8个AI论文改写工具评测,降重与写作功能全面分析
  • Elasticsearch基本用法项目应用:分页与高亮处理
  • 基于proteus的4位数码管动态扫描实战案例
  • 全面讲解ESP32开发核心外设:GPIO控制基础教学
  • PaperzzAI PPT:别再熬夜做PPT了,让AI给你“一键生成高光时刻”——不是模板搬运工,是你的视觉导演+内容编剧
  • 图解说明Vitis使用教程:适合初学者的界面功能解析
  • 具身智能重构体验!CES Asia 2026:消费电子从“工具”变身“主动伙伴”
  • STM32-时钟树编程
  • Packet Tracer使用教程:OSPF基础配置图解说明
  • 批量部署USB转串口驱动的企业级Windows策略应用
  • 赋能成长型企业:SAP Business One与奥维奥的数字化共赢之道
  • 一文说清同步整流buck电路图及其工作原理
  • Packet Tracer下载步骤详解:适合初学者的系统学习
  • 2025年AI论文写作平台精选,集成LaTeX支持与智能格式检查
  • Hotkey Detective终极指南:3步解决Windows热键冲突难题
  • 【Mol Plant综述精读】植物中的染色质重塑:复合物组成、机制多样性及生物学功能
  • 基于GA-HIDMSPSO算法优化BP神经网络+NSGAII多目标优化算法工艺参数优化、工程设计优化(四目标优化案例)
  • 系统学习erase前必须知道的存储基础知识
  • 通俗解释定制ROM在2025机顶盒刷机中的作用机制
  • 【数据分析】基于逆向方法的新型神经网络的实现,以估计云杉音木薄板的材料特性附Matlab代码
  • 微信小程序二维码生成实战指南:3步实现个性化营销码
  • 终极指南:如何使用Keyboard Chatter Blocker解决机械键盘连击问题
  • Performance-Fish性能优化指南:让《环世界》告别卡顿的5大秘诀
  • GKD订阅管理难题:如何用简单方法解决复杂问题
  • Windows热键失灵怎么办?这款侦探工具帮你快速定位问题