首页 > 编程语言 >【数据结构和算法实践-树-LeetCode113-路径总和Ⅱ】

【数据结构和算法实践-树-LeetCode113-路径总和Ⅱ】

时间:2024-09-15 13:52:56浏览次数:3  
标签:node null LeetCode113 List 算法 targetSum processList 数据结构 节点

数据结构和算法实践-树-LeetCode113-路径总和Ⅱ

题目

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。
叶子节点 是指没有子节点的节点
输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

My Thought

题目限定的条件为是否存在到叶子节点的路径总和与目标相等:
一、参考之前的路径总和
二、需要注意的是,每个节点其实要回退到node的,不然会无限扩展
然后再进行递归,递归要注意两个方面:
一、自我调用
二、终止条件:即函数边界
注意点:树、递归

代码示例

JAVA-8

    static List<List<Integer>> resultAll = new ArrayList<>();

    public List<List<Integer>> pathSum(TreeNode root, int targetSum) {
        List<List<Integer>> result = new ArrayList<>();
        List<Integer> processList = new ArrayList<>();
        if (root == null) {
            return result;
        }
        if(resultAll != null){
            resultAll.clear();
        }
        process(root, 0, targetSum, processList);
        return resultAll;
    }

    private static void process(TreeNode node, int preSum, int targetSum, List<Integer> processList) {
        if (node == null) {
            return;
        }
        if (node.left == null && node.right == null) {
            if (node.val + preSum == targetSum) {
                processList.add(node.val);
                List<Integer> resultList = new ArrayList<>();
                for (Integer n : processList) {
                    resultList.add(n);
                }
                resultAll.add(resultList);
                processList.remove(processList.size() - 1);
            }
        }
        processList.add(node.val);
        preSum += node.val;
        process(node.left, preSum, targetSum, processList);
        process(node.right, preSum, targetSum, processList);
        processList.remove(processList.size() - 1);
    }

标签:node,null,LeetCode113,List,算法,targetSum,processList,数据结构,节点
From: https://blog.csdn.net/Mao_c/article/details/142257391

相关文章

  • 痞子衡嵌入式:JLink命令行以及JFlash对于下载算法的作用地址范围认定QN
    大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是JLink命令行以及JFlash对于下载算法的作用地址范围认定。最近痞子衡在给一个RT1170客户定制一个InfineonMirrorBit类型64MBFlash的SEGGER下载算法,做完之后在JFlash下测试小数据下载没有问题,但......
  • 数据结构之快速排序、堆排序概念与实现举例
    1、快速排序快速排序是一种高效的排序算法,采用分治法策略。它的基本思想是:通过一个划分操作,将待排序的数组分为两个(尽可能)均等的子数组,使得左侧子数组中的所有元素都不大于右侧子数组中的任何元素,然后对这两个子数组分别进行快速排序,整个排序过程可以递归进行,以此达到整个......
  • 数据结构之希尔排序
    1、希尔排序希尔排序是一种基于插入排序的算法,通过比较相距一定间隔的元素来工作,然后逐渐减少这个间隔,直到它变为1,此时算法退化为简单插入排序,但此时,大部分元素已经是基本有序的,所以最后的插入排序效率很高。2、希尔排序说明与举例希尔排序是一种基于插入排序的高效排序......
  • 探索C#编程:高效解决N皇后问题的回溯算法实现
    在C#中,回溯算法是一种通过探索所有可能的候选解来找出所有解的算法。如果候选解被确认不是一个解(或者至少不是最后一个解),回溯算法会通过在上一步进行一些变化来撤销上一步或上几步的计算,以获得新的候选解。这个过程一直进行,直到找到所有解或确定无解。回溯算法常用于解决组......
  • 数学建模常用模型---“算法”总结(含特性和应用场景)
    目录数学建模常用模型算法总结1.代数模型(AlgebraicModels)2.微分方程模型(DifferentialEquationModels)3.概率模型(ProbabilisticModels)4.优化模型(OptimizationModels)5.统计模型(StatisticalModels)6.机器学习模型(MachineLearningModels)7.网络和图论模型(Network......
  • redis基本数据结构-set
    文章目录1.set的基本介绍1.1.set底层结构之hash表的简单介绍1.2.常用命令2.常见的业务场景2.1.标签系统2.2.社交网络好友关系1.set的基本介绍参考链接:https://mp.weixin.qq.com/s/srkd73bS2n3mjIADLVg72Aredis的set数据结构是一个无序的集合,可以存储不......
  • 分布式学习:Raft算法以及具体实现
    Raft算法一致性算法的要求:安全性,网络延迟、分区、丢包、重复和乱序等错误需要保证正确可用性:集群中只需要大多数机器即可运行不依赖时序保证一致性三种状态:follower,candidate,leader任期:逻辑时钟的作用,每一段任期从一次选举开始分票可能会导致一个任期没有leader用......
  • [独家原创]基于(牛顿拉夫逊)NRBO-Transformer单变量时序预测-递归预测未来数据 【24年
    [独家原创]基于(牛顿拉夫逊)NRBO-Transformer单变量时序预测-递归预测未来数据【24年新算法】(单输入单输出)你先用你就是创新!!!可以自行控制预测未来的数据个数!!!NRBO优化的超参数为:自注意力机制头数、正则化系数、初始化学习率1.程序已经调试好,无需更改代码替换数据集即可运行......
  • 十大经典排序算法
    排序算法平均时间复杂度最好情况最坏情况空间复杂度排序方式稳定性冒泡排序O(n^2)O(n)O(n^2)O(1)in-place稳定选择排序O(n^2)O(n^2)O(n^2)O(1)in-place不稳定插入排序O(n^2)O(n)O(n^2)O(1)in-place稳定希尔排序O(nlogn)O(nlog^2n)O(nlog^2n)O(1)in-place不稳定归并排序O(......
  • 【67种改进策略】优化算法改进再也不用担心了-matlab代码
    仅需一行代码,学会从入门到创新改进所有群智能优化算法   目录  引言一.佳点集初始化二.21种混沌初始化三.21种混沌参数化四.13种变异策略五.10种飞行/分布函数六.单纯形Nelder‑Mead单纯形法(Nelder‑Meadsimplex)Matlab代码下载点击链接跳转:引言根据“......