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

相关文章

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi