LeetCode路径总和系列问题解析:I、II、III的解决方案与优化

文章目录

    • 引言
    • 一、路径总和 I(LeetCode 112)
      • 问题描述
      • 方法思路
      • Java代码实现
      • 复杂度分析
    • 二、路径总和 II(LeetCode 113)
      • 问题描述
      • 方法思路
      • Java代码实现
      • 复杂度分析
    • 三、路径总和 III(LeetCode 437)
      • 问题描述
      • 方法思路
      • Java代码实现
      • 复杂度分析
    • 四、对比与总结
      • 方法对比
      • 总结
    • 五、示例验证
      • 路径总和II示例
      • 路径总和III示例

引言

路径总和系列是二叉树遍历中的经典问题,涵盖从基础递归到高级优化的多种解法。本文详细分析LeetCode中路径总和I、II、III的解题思路,并提供Java实现代码与优化技巧,帮助读者深入理解二叉树遍历与回溯算法的应用。


一、路径总和 I(LeetCode 112)

问题描述

判断二叉树中是否存在从根节点到叶子节点的路径,使得路径节点值之和等于给定目标数。

方法思路

  • 递归遍历:深度优先搜索(DFS)遍历每个节点。
  • 终止条件
    • 空节点直接返回false
    • 叶子节点判断当前剩余值是否等于节点值。
  • 递归逻辑:对左右子树递归检查剩余目标值。

Java代码实现

class Solution {public boolean hasPathSum(TreeNode root, int targetSum) {if (root == null) return false;if (root.left == null && root.right == null) {return targetSum == root.val;}return hasPathSum(root.left, targetSum - root.val) || hasPathSum(root.right, targetSum - root.val);}
}

复杂度分析

  • 时间复杂度:O(n),每个节点访问一次。
  • 空间复杂度:O(n),递归栈深度在最坏情况下(树退化为链表)为n。

二、路径总和 II(LeetCode 113)

问题描述

找出所有从根节点到叶子节点路径和等于目标数的路径,返回路径列表。

方法思路

  • 回溯法:通过动态维护路径列表记录当前路径。
  • 关键步骤
    1. 添加当前节点到路径。
    2. 到达叶子节点时检查路径和。
    3. 递归返回前移除当前节点(回溯)。

Java代码实现

class Solution {public List<List<Integer>> pathSum(TreeNode root, int targetSum) {List<List<Integer>> result = new ArrayList<>();dfs(root, targetSum, new ArrayList<>(), result);return result;}private void dfs(TreeNode node, int remain, List<Integer> path, List<List<Integer>> result) {if (node == null) return;path.add(node.val);if (node.left == null && node.right == null && remain == node.val) {result.add(new ArrayList<>(path)); // 深拷贝路径} else {dfs(node.left, remain - node.val, path, result);dfs(node.right, remain - node.val, path, result);}path.remove(path.size() - 1); // 回溯}
}

复杂度分析

  • 时间复杂度:O(n),每个节点访问一次。
  • 空间复杂度:O(n²),存储所有路径的空间开销。

三、路径总和 III(LeetCode 437)

问题描述

统计路径和等于目标数的路径数量。路径方向必须向下,但起点和终点不限制。

方法思路

  • 前缀和+哈希表优化
    • 记录路径前缀和及其出现次数。
    • 若当前前缀和为currentSum,查找currentSum - target是否存在。
  • 回溯维护:递归后需清理当前前缀和,避免影响其他子树。

Java代码实现

class Solution {private int count = 0;private Map<Long, Integer> prefixMap = new HashMap<>();public int pathSum(TreeNode root, int targetSum) {prefixMap.put(0L, 1); // 初始化空路径dfs(root, 0L, targetSum);return count;}private void dfs(TreeNode node, long currentSum, int target) {if (node == null) return;currentSum += node.val;count += prefixMap.getOrDefault(currentSum - target, 0);prefixMap.put(currentSum, prefixMap.getOrDefault(currentSum, 0) + 1);dfs(node.left, currentSum, target);dfs(node.right, currentSum, target);prefixMap.put(currentSum, prefixMap.get(currentSum) - 1); // 回溯}
}

复杂度分析

  • 时间复杂度:O(n),每个节点访问一次。
  • 空间复杂度:O(n),哈希表存储前缀和。

四、对比与总结

方法对比

问题核心方法时间复杂度空间复杂度关键难点
路径总和 I递归遍历O(n)O(n)终止条件判断
路径总和 II回溯+路径记录O(n)O(n²)深拷贝与回溯逻辑
路径总和 III前缀和+哈希表O(n)O(n)前缀和统计与回溯维护

总结

  1. 路径总和I:基础递归应用,理解终止条件与递归分解。
  2. 路径总和II:掌握回溯法维护路径状态,注意深拷贝避免引用问题。
  3. 路径总和III:前缀和优化是核心,通过空间换时间避免重复计算。

五、示例验证

路径总和II示例

输入:

       5/ \4   8/   / \11  13  4/  \    / \7    2  5   1

目标值:22
输出:[[5,4,11,2], [5,8,4,5]]

路径总和III示例

输入:

      10/  \5   -3/ \    \3   2   11/ \   \
3  -2   1

目标值:8
输出:3(路径为5→3, 5→2→1, -3→11


通过系统化分析与代码实现,读者可深入掌握二叉树路径问题的多种解法,提升算法设计与优化能力。

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

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

相关文章

NFC 碰一碰发视频贴牌技术,音频功能的开发实践与技术解析

在数字化营销与信息交互场景中&#xff0c;NFC 碰一碰技术凭借其便捷性和高效性&#xff0c;成为快速传递多媒体内容的新选择。通过 NFC 实现视频音频的快速传输&#xff0c;不仅能提升用户体验&#xff0c;还能为各类场景带来创新应用。本文将深入探讨该功能开发过程中的关键技…

跨境电商生死劫:IP筛查三法则破解封号魔咒

一、血泪数据&#xff1a;90%封号案源于IP污染 跨境电商平台风控系统持续升级&#xff0c;2023年亚马逊全球封号案例中&#xff0c;67%涉及账号关联&#xff08;Marketplace Pulse数据&#xff09;&#xff0c;其中IP问题占比高达91%。更触目惊心的是&#xff1a; 新号存活率&…

MIPS架构详解:定义、应用与其他架构对比

一、MIPS架构的定义 MIPS&#xff08;Microprocessor without Interlocked Pipeline Stages&#xff09; 是一种经典的精简指令集&#xff08;RISC&#xff09;处理器架构&#xff0c;由斯坦福大学John Hennessy团队于1981年提出&#xff0c;强调高效流水线设计和硬件简化。 核…

第十六届蓝桥杯 2025 C/C++组 脉冲强度之和

目录 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; 思路&#xff1a; 思路详解&#xff1a; 代码&#xff1a; 代码详解&#xff1a; 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; P12338 [蓝桥杯 2025 省 B/Python B 第二场] 脉冲强度…

从Ping到iperf3:深度实战无线网络压测与优化指南

以下是测试无线网络稳定性的详细步骤与工具指南&#xff0c;涵盖信号质量、吞吐量、干扰排查等关键维度&#xff1a; 一、基础信号质量测试 1. 信号强度与覆盖测试 工具&#xff1a;手机APP&#xff08;WiFi Analyzer、NetSpot&#xff09;或笔记本&#xff08;Acrylic WiFi&a…

MySQL 连接池 (Pool) 常用方法详解

MySQL 连接池 (Pool) 常用方法详解 1. 创建连接池 首先需要创建连接池实例&#xff1a; const mysql require(mysql2/promise); // 使用Promise版本const pool mysql.createPool({host: localhost,user: root,password: password,database: test,waitForConnections: true…

大型连锁酒店集团数据湖应用示例

目录 一、应用前面临的严峻背景 二、数据湖的精细化构建过程 &#xff08;一&#xff09;全域数据整合规划 &#xff08;二&#xff09;高效的数据摄取与存储架构搭建 &#xff08;三&#xff09;完善的元数据管理体系建设 &#xff08;四&#xff09;强大的数据分析平台…

GNU gettext 快速上手

文章目录 1.简介2.核心概念国际化 (i18n)本地化 (l10n)POT 文件PO 文件MO 文件文本域翻译函数 3.主要组件4.使用示例参考文献 1.简介 GNU gettext 是一套用于软件国际化&#xff08;internationalization&#xff0c;i18n&#xff09;和本地化&#xff08;localization&#x…

分享:VTK版本的选择 - WPF空域问题

在早期版本中&#xff0c;ActiViz 对 Windows Presentation Foundation (WPF) 框架的支持是通过 WindowsFormHost 组件实现的&#xff0c;这种方式依赖于 WindowsForm 和 WPF 的互操作性。然而&#xff0c;这种方法存在一个众所周知的“空域问题”&#xff08;airspace issue&a…

python数据分析(六):Pandas 多数据操作全面指南

Pandas 多数据操作全面指南&#xff1a;Merge, Join, Concatenate 与 Compare 1. 引言 在数据分析工作中&#xff0c;我们经常需要处理多个数据集并将它们以各种方式组合起来。Pandas 提供了多种强大的多数据操作方法&#xff0c;包括合并(merge)、连接(join)、连接(concaten…

spring 面试题

一、Spring 基础概念 什么是 Spring 框架&#xff1f; Spring 是一个开源的 Java 应用程序框架&#xff0c;它提供了一种轻量级的、非侵入式的方式来构建企业级应用。Spring 的核心功能包括依赖注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;、面向切面编程…

OpenCV-Python (官方)中文教程(部分一)_Day20

22.直方图 22.1直方图的计算,绘制与分析 使用 OpenCV 或 Numpy 函数计算直方图 使用 Opencv 或者 Matplotlib 函数绘制直方图 将要学习的函数有&#xff1a;cv2.calcHist(),np.histogram() 什么是直方图呢&#xff1f;通过直方图你可以对整幅图像的灰度分布有一个整体的 了…

数电发票整理:免费实用工具如何高效解析 XML 发票数据

如今数字电子发票越来越普及&#xff0c;但是数电发票的整理还是颇有讲究~ 今天给大家介绍一个 XML 发票阅读器。使用它完全不收取任何费用&#xff0c;且无广告干扰&#xff0c;对财务人员而言十分实用。 01 软件介绍 这款软件就是XML格式&#xff08;数电票&#xff09;阅读…

深度学习正则化:原理、方法与应用深度解析

摘要 本文深入探讨深度学习中的正则化技术&#xff0c;介绍其避免过拟合的重要性&#xff0c;详细讲解常见的正则化方法&#xff0c;如 L 1 L_1 L1​和 L 2 L_2 L2​正则化、Dropout等&#xff0c;并通过线性回归案例和神经网络训练流程对其进行直观阐释。帮助读者理解正则化原…

【爬虫】deepseek谈爬虫工具

2025 年&#xff0c;随着 Web 技术的演进和反爬机制的升级&#xff0c;工具生态也会进一步优化。以下是 2025 年爬虫 & 自动化测试的前沿工具预测&#xff0c;结合行业趋势和现有技术发展方向&#xff1a; &#x1f680; 2025 年推荐组合&#xff08;预测版&#xff09; 1…

SQLMesh 测试自动化:提升数据工程效率

在现代数据工程中&#xff0c;确保数据模型的准确性和可靠性至关重要。SQLMesh 提供了一套强大的测试工具&#xff0c;用于验证数据模型的输出是否符合预期。本文将深入探讨 SQLMesh 的测试功能&#xff0c;包括如何创建测试、支持的数据格式以及如何运行和调试测试。 SQLMesh …

Java学习手册:Spring 中常用的注解

一、组件注解 Component &#xff1a;用于标记一个类为 Spring 管理的 Bean&#xff0c;是 Spring 的基本组件注解。Spring 会通过类路径扫描自动检测并注册标记了 Component 的类为 Bean。Service &#xff1a;是 Component 的派生注解&#xff0c;用于标记服务层类&#xff…

前端跨域问题详解:原因、解决方案与最佳实践

引言 在现代Web开发中&#xff0c;跨域问题是前端工程师几乎每天都会遇到的挑战。随着前后端分离架构的普及和微服务的发展&#xff0c;跨域请求变得愈发常见。本文将深入探讨跨域问题的本质、各种解决方案以及在实际开发中的最佳实践。 一、什么是跨域问题&#xff1f; 1.1…

[计算机网络]物理层

文章目录 物理层的概述与功能传输介质双绞线:分类:应用领域: 同轴电缆&#xff1a;分类: 光纤&#xff1a;分类: 无线传输介质&#xff1a;无线电波微波&#xff1a;红外线&#xff1a;激光&#xff1a; 物理层设备中继器&#xff1a;放大器&#xff1a;集线器(Hub)&#xff1a…

大连理工大学选修课——机器学习笔记(9):线性判别式与逻辑回归

线性判别式与逻辑回归 概述 判别式方法 产生式模型需要计算输入、输出的联合概率 需要知道样本的概率分布&#xff0c;定义似然密度的隐式参数也称为基于似然的分类 判别式模型直接构造判别式 g i ( x ∣ θ i ) g_i(x|\theta_i) gi​(x∣θi​)&#xff0c;显式定义判别式…