113. 路径总和 II

技术113. 路径总和 II 113. 路径总和 II113. 路径总和 II
题目链接:113. 路径总和 II(中等)
给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有

113.路径总和二

113. 路径总和 II

题目链接:113.路径总和二(中等)

给你二叉树的根节点根和一个整数目标和targetSum,找出所有从根节点到叶子节点路径总和等于给定目标和的路径。

叶子节点是指没有子节点的节点。

示例 1:

输入:root=[5,4,8,11,null,13,4,7,2,null,null,5,1],targetSum=22

输出:[[5,4,11,2],[5,8,4,5]]

示例 2:

输入:root=[1,2,3],targetSum=5

输出:[]

示例 3:

输入:root=[1,2],targetSum=0

输出:[]

解题思路

该题与112.路径总和类似,不一样的是该题需要遍历完所有的路径。

递归法

代码(C++)

//递归

解决方案类{

公众号:

空的遍历(TreeNode* node,矢量路径,矢量结果,int计数){ 0

if(!节点-左边!节点-右侧){ 0

if (count==0) result.push_back(路径);

返回;

}

如果(左节点){ 0

路径。push _ back(node-left-val);

count-=node-left-val;

遍历(左节点、路径、结果、计数);//递归

计数=节点-左-瓦尔;//回溯

路径。pop _ back();//回溯

}

如果(节点-右侧){ 0

路径。push _ back(node-right-val);

count-=node-right-val;

遍历(右节点、路径、结果、计数);//递归

count=node-right-val;//回溯

路径。pop _ back();//回溯

}

}

vectorvectorntpathsum(TreeNode * root,int TargetSum){ 0

向量向量结果;

if (root==nullptr)返回结果;

向量路径;

路径。push _ back(root-val);

遍历(根、路径、结果、TargetSum-root-val);

返回结果;

}

};

代码(JavaScript)

/**

* @param {TreeNode}根目录

* @param {number} targetSum

* @return {number[][]}

*/

函数遍历(节点、路径、结果、计数){ 0

if(!节点。左边!节点。右){ 0

if (count===0) result.push([.路径]);//不能写结果。推送(路径),要深拷贝

返回;

}

if(节点。左){ 0

路径。push(节点。向左。val);

count-=节点。向左。瓦尔;

遍历(node.left,path,result,count);//递归

计数=节点。向左。瓦尔;//回溯

路径。pop();//回溯

}

if(节点。右){ 0

路径。push(节点。没错。val);

count-=节点。没错。瓦尔;

遍历(node.right,path,result,count);//递归

计数=节点。没错。瓦尔;//回溯

路径。pop();//回溯

}

返回错误的

}

var pathSum=函数(根,TargetSum){ 0

让结果=[];

if (root===null)返回结果;

让路径=[];

路径。push(root。val);

遍历(根、路径、结果、TargetSum-root。val);

返回结果;

};

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/141438.html

(0)

相关推荐

  • 怎么提高下载速度,如何让电脑下载速度变得更快

    技术怎么提高下载速度,如何让电脑下载速度变得更快如题所述如何让下载速度变快怎么提高下载速度?在电脑日常的使用过程中,下载文件,往往会遇到下载缓慢,或突然中断的现象
    怎么怎样才能提高电脑的下载速度?
    首先,最基本的就是,网

    生活 2021年10月28日
  • 戛然而止是什么意思,“戛然而止”的“戛”是什么意思

    技术戛然而止是什么意思,“戛然而止”的“戛”是什么意思意思是:象声词一戛然而止是什么意思、戛的组词:戛然、戛玉、摩戛、戛云、戛击、排戛、嘐戛、磨戛、戛羹、交戛、戛齿、戛敔、铿戛、硗戛、戛触、相戛、戛摩、戛服、戛磨、击戛二

    生活 2021年10月25日
  • 箱线图怎么画,SPSS中如何绘制箱图

    技术箱线图怎么画,SPSS中如何绘制箱图箱线图主要包含六个数据节点,将一组数据从大到小排列,分别计算出它的上边缘箱线图怎么画、上四分位数、 中位数、下四分位数、下边缘,还有一个异常值。工具/原料电脑:组装台式机系统:wi

    生活 2021年10月27日
  • NHibernate是什么

    技术NHibernate是什么本篇内容介绍了“NHibernate是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!N

    攻略 2021年12月4日
  • mysql 发生系统错误1067(mysql数据库1067错误是怎么回事)

    技术mysql出现服务1067错误怎么办这篇文章将为大家详细讲解有关mysql出现服务1067错误怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 my

    攻略 2021年12月22日
  • ajax 执行函数(ajax回调函数)

    技术ajax函数怎么使用本篇内容主要讲解“ajax函数怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ajax函数怎么使用”吧! ajax函

    攻略 2021年12月17日