当前位置: 首页 > 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.zskr.cn/news/138004.html

相关文章:

  • Java计算机毕设之基于springboot的旧物回收商城系统的设计与实现基于Springboot的旧物置换网站实现(完整前后端代码+说明文档+LW,调试定制等)
  • 基于Springboot企业进销存管理系统【附源码+文档】
  • 工业现场总线替代方案:SerialPort技术可行性分析
  • 专用蚊子苍蝇检测数据集(含背景样本):适用于目标检测任务
  • OpenMV识别物体结合WiFi传输的安防监控:项目实践
  • c++进程池(Linux)的实现(2025.12.22)
  • 基于SpringBoot的青年大学习记录管理系统的设计与实现
  • es面试题从零实现:初级岗位应知应会汇总
  • AUTOSAR网络管理节点状态机配置的实战操作指南
  • 【保姆级教程】2025最新 WordPress 建站全流程,从零到一实现网站上线(建议收藏)
  • 无法通过 scp 上传文件至路由器解决方法
  • Paperzz 毕业论文 AI 功能:把 “论文熬大夜” 变成 “四步出框架” 的毕业捷径
  • 堆排序--自学笔记
  • GEO优化公司优质推荐:这六家企业技术扎实,长期效果经得起考验 - 品牌企业推荐师(官方)
  • 8个AI论文生成平台测评,降重与写作功能深度解析
  • Paperzz AI PPT:把 “做 PPT 的苦”,变成 “选模板的爽”
  • 工业热成像数据增强不足 后来才知道加高斯噪声模拟设备老化
  • CC2530运行ZStack时的中断处理机制解析
  • 基于 FRP + 云服务器实现安全可靠的远程桌面连接
  • AI论文生成工具排行榜:8个优质网站推荐,涵盖降重与写作功能
  • 毕业季 “学术搭子” 清单:7 个 AI 工具,把论文焦虑按在地上摩擦
  • Java毕设项目:基于springboot的非物质文化遗产再创新系统设计与实现(源码+文档,讲解、调试运行,定制等)
  • 国内IT软考证报考流程及前期准备,一篇解读
  • 完整示例演示USB Burning Tool刷写失败排查方法
  • Qt 信号与槽机制深度解析
  • Java毕设选题推荐:基于springboot的旧物回收商城系统的设计与实现springboot废物回收管理商城【附源码、mysql、文档、调试+代码讲解+全bao等】
  • LACP协议小结
  • 全面讲解ESP32开发核心外设:GPIO控制基础教学
  • STM32CubeMX中文汉化环境下I2C配置流程通俗解释
  • 有源蜂鸣器和无源区分:手把手教你辨认方法