博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
根节点到叶子节点的节点值之和等于 sum的路径
阅读量:4042 次
发布时间:2019-05-24

本文共 1123 字,大约阅读时间需要 3 分钟。

DESC:

题目描述

给定一个二叉树和一个值 sum,请找出所有的根节点到叶子节点的节点值之和等于 sum 的路径,

例如:
给出如下的二叉树, sum=22,

返回

[
[5,4,11,2],
[5,8,9]
]

示例1

输入

{1,2},1

返回值

[]

示例2

输入

{1,2},3

返回值

[[1,2]]

 

CODE:

import java.util.*;/* * public class TreeNode { *   int val = 0; *   TreeNode left = null; *   TreeNode right = null; * } */public class Solution {    /**     *      * @param root TreeNode类      * @param sum int整型      * @return int整型ArrayList
<>> */ private ArrayList
> res = new ArrayList<>(); public ArrayList
> pathSum (TreeNode root, int sum) { // write code here ArrayList
temp = new ArrayList(); dfs(root, sum, 0, temp); return res; } private void dfs(TreeNode node, int sum, int pathSum, ArrayList
path){ if (node == null) { return; } path.add(node.val); pathSum += node.val; if (node.left == null && node.right == null && sum == pathSum) { res.add(new ArrayList<>(path)); } else { dfs(node.left, sum, pathSum, path); dfs(node.right, sum, pathSum, path); } path.remove(path.size()-1); }}

 

 

DESC:

  1. DFS, 回溯
  2. 注意每一层执行完,删除当前节点的val,即回溯,便于上层左右节点拼接路径

转载地址:http://nfldi.baihongyu.com/

你可能感兴趣的文章
慢慢欣赏linux make uImage流程
查看>>
linux内核学习(7)脱胎换骨解压缩的内核
查看>>
以太网基础知识
查看>>
慢慢欣赏linux 内核模块引用
查看>>
kprobe学习
查看>>
慢慢欣赏linux phy驱动初始化2
查看>>
慢慢欣赏linux CPU占用率学习
查看>>
2020年终总结
查看>>
Homebrew指令集
查看>>
React Native(一):搭建开发环境、出Hello World
查看>>
React Native(二):属性、状态
查看>>
JSX使用总结
查看>>
React Native(四):布局(使用Flexbox)
查看>>
React Native(七):Android双击Back键退出应用
查看>>
Android自定义apk名称、版本号自增
查看>>
adb command not found
查看>>
Xcode 启动页面禁用和显示
查看>>
【剑指offer】q50:树中结点的最近祖先
查看>>
二叉树的非递归遍历
查看>>
【leetcode】Reorder List (python)
查看>>