迭代法求从根到叶的二进制数之和 迭代我们用栈来模拟递归同时使用一个 prev 指针来记录先前访问的节点。算法步骤如下我们用栈来模拟递归同时使用一个 prev 指针来记录先前访问的节点。算法步骤如下如果节点 root 非空我们将不断地将它及它的左节点压入栈中。我们从栈中获取节点该节点的右节点为空或者等于 prev 说明该节点的左子树及右子树都已经被访问我们将它出栈。如果该节点是叶子节点我们将它对应的数字 val 加入结果中。设置 prev 为该节点设置 root 为空指针。该节点的右节点非空且不等于 prev ,我们令 root 指向该节点的右节点。3.如果 root 为空指针或者栈空中止算法否则重复步骤 1。需要注意的是每次出入栈都需要更新 val 。代码Python3class Solution: def sumRootToLeaf(self, root: Optional[TreeNode]) - int: ans val 0 st [] pre None while root or st: while root: val (val 1) | root.val st.append(root) root root.left root st[-1] if root.right is None or root.right pre: if root.left is None and root.right is None: ans val val 1 st.pop() pre root root None else: root root.right return ansJavaclass Solution { public int sumRootToLeaf(TreeNode root) { DequeTreeNode stack new ArrayDequeTreeNode(); int val 0, ret 0; TreeNode prev null; while (root ! null || !stack.isEmpty()) { while (root ! null) { val (val 1) | root.val; stack.push(root); root root.left; } root stack.peek(); if (root.right null || root.right prev) { if (root.left null root.right null) { ret val; } val 1; stack.pop(); prev root; root null; } else { root root.right; } } return ret; } }Cclass Solution { public: int sumRootToLeaf(TreeNode* root) { stackTreeNode * st; int val 0, ret 0; TreeNode *prev nullptr; while (root ! nullptr || !st.empty()) { while (root ! nullptr) { val (val 1) | root-val; st.push(root); root root-left; } root st.top(); if (root-right nullptr || root-right prev) { if (root-left nullptr root-right nullptr) { ret val; } val 1; st.pop(); prev root; root nullptr; } else { root root-right; } } return ret; } };复杂度分析时间复杂度O(n) 其中 n 是节点数目。总共访问 n 个节点。空间复杂度O(n) 。栈最多压入 n 个节点。

相关新闻

最新新闻

MC6470与PIC18F24J50的6DOF传感器系统开发指南

MC6470与PIC18F24J50的6DOF传感器系统开发指南

1. MC6470与PIC18F24J50的硬件组合解析MC6470是一款6自由度(6DOF)惯性测量单元(IMU),集成了三轴加速度计和三轴磁力计。这款MEMS传感器采用MEMSIC独有的热对流技术,相比传统电容式MEMS具有更高的可靠性和抗冲击能力。其典型参数包括:加速度计…

2026/7/3 19:08:42
技术指南:开源工具实现联想笔记本BIOS高级配置终极方案

技术指南:开源工具实现联想笔记本BIOS高级配置终极方案

技术指南:开源工具实现联想笔记本BIOS高级配置终极方案 【免费下载链接】LEGION_Y7000Series_Insyde_Advanced_Settings_Tools 支持一键修改 Insyde BIOS 隐藏选项的小工具,例如关闭CFG LOCK、修改DVMT等等 项目地址: https://gitcode.com/gh_mirrors/…

2026/7/3 19:08:42
MCP 2026高危漏洞应急响应:5步实操加固与长效管理机制

MCP 2026高危漏洞应急响应:5步实操加固与长效管理机制

1. 项目概述:当MCP 2026高危漏洞警报拉响 凌晨三点,安全告警平台的蜂鸣声把我从睡梦中拽了起来。屏幕上,来自资产扫描器的报告赫然列着几个新出现的CVE编号:CVE-2026-0891、CVE-2026-0947、CVE-2026-1123,风险等级全是…

2026/7/3 19:08:42
防火墙实战:封堵Traceroute探测与加固ICMP时间戳漏洞

防火墙实战:封堵Traceroute探测与加固ICMP时间戳漏洞

1. 项目概述:从一次真实的网络异常告警说起那天凌晨,监控系统突然弹出一条告警,显示核心业务服务器的网络延迟出现周期性尖峰。登录设备一看,traceroute的探测包像潮水一样从几个陌生的IP涌来,虽然没造成业务中断&…

2026/7/3 19:08:41
STM32低功耗矩阵键盘设计:硬件与软件协同优化

STM32低功耗矩阵键盘设计:硬件与软件协同优化

1. 项目背景与核心需求 在嵌入式系统开发中,如何用最精简的硬件资源实现高效的人机交互一直是个经典问题。最近我在一个低功耗环境监测设备项目中,遇到了一个典型场景:设备需要支持4个功能切换(数据查看、参数设置、校准模式和系统…

2026/7/3 19:08:41
Python实现SM4国密算法:从原理到实战加密解密

Python实现SM4国密算法:从原理到实战加密解密

1. 项目概述:为什么要在Python里实现SM4?如果你正在处理一些对数据安全有特定要求的项目,比如金融交易、政务系统对接,或者仅仅是出于学习目的想深入了解国密算法,那么SM4加密算法很可能已经进入了你的视野。SM4&#…

2026/7/3 19:03:41

周新闻

月新闻