LeetCode详解 之 Path Sum I and II(Java)

2024-09-03 03:32
文章标签 java leetcode 详解 ii path sum

本文主要是介绍LeetCode详解 之 Path Sum I and II(Java),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目
Path Sum I:
Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that adding up all the values along the path equals the given sum.
For example:
Given the below binary tree and  sum = 22 ,
Path Sum II:

Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given sum.

For example:
Given the below binary tree and  sum = 22 ,
              5/ \4   8/   / \11  13  4/  \    / \7    2  5   1
需要返回的是:
 
[[5,4,11,2],[5,8,4,5]
]
也就是说第一题要求我们在一个二叉树上面,看是否有一条路径上所有的节点的值加起来等于我们所需要的这个固定的值。第二题难度加大了,在第一题的基础上面,要求找出所有的路径并且把这些路径用一个List表示出来。本题考察的依然是对树进行操作,以及对于双重List的用法,这对于刚刚接触数据结构和java的人来说还是略有难度。那么下面我们就一一来对这两道题目的程序进行详细的讲解。


程序及讲解:
那么第一题我给出了一种非常简单的方法,几行代码就可以把题目要求搞定,这样省去了大量的时间去进行下一环节的面试。
Path Sum I:
public class Solution {
    public boolean hasPathSum(TreeNode root, int sum) {
          if(root==null) return false;
          else if(root.left==null && root.right==null)
          return root.val==sum;
          else 
          sum=sum-root.val;
          return hasPathSum(root.left,sum)||hasPathSum(root.right,sum);
    }
}
在这里,我们直接进行了迭代(个人爱好),把程序交给下一步进行自动完成,只需要少量的代码来控制边界条件,此题过于简单就不做详细的解释了

Path Sum II:
public class Solution {
public ArrayList> pathSum(TreeNode root, int sum) {
          ArrayList> result = new ArrayList>();
          if (root == null)
                return result;
          recursivePathSum(root, sum, new ArrayList(), result);
          return result;
    }
private void recursivePathSum(TreeNode root, int sum, ArrayList current,ArrayList> result) 
    {
          if (root == null)         
return;
          if (root.val == sum && root.left == null && root.right == null) {
                current.add(root.val);
                result.add(new ArrayList(current));
                current.remove(current.size()-1);
                return;
       }
          current.add(root.val);
          recursivePathSum(root.left, sum-root.val, current, result);
          recursivePathSum(root.right, sum-root.val, current, result);
          current.remove(current.size()-1);
    }
}

在这里,首先我们看到函数返回的是一个二维arraylist,这个是非常好用的一个java独有的一个东西,继承自List具有List的大量属性外,还具有add,remove等功能,可查阅API
首先check root,如果是null就返回刚刚建好的空的ArrayList,那么这个新建的方法中,没有返回任何值,但是却对result进行了一系列的操作,最终返回result。
那么重点就在这个我们新建的方法,如何才能很有效的实现这个方法:
如果只有一个根节点有值切恰恰等于那个值,OK,直接装上走人,如果没有,不着急,再进行遍历,我把根节点值保存在current这个arraylist中,再一次遍历左边的节点和右边的节点,直到程序结束。
细节在于每次current完了以后要对他的size进行一次remove
arraylist.remove(index)的方法是remove掉index这个点的值。

这篇关于LeetCode详解 之 Path Sum I and II(Java)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131898

相关文章

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2