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实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2