二叉树中和为某一值的路径
题目描述:
输入一颗二叉树的根节点和一个整数,按字典序打印出二叉树中结点值的和为输入整数的所有路径。
路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。
题目解析:
1.首先前序遍历,将访问的结点加入到路径中 并累加该路径结点的值;
2.如果该结点是叶子结点 且路径上的累加值等于输入的数字,则当前路径符合要求,直接返回路径;
3.如果该结点不是叶子结点,继续递归访问它的左右子节点;
注意:当前结点为叶子节点 但是路径不符合要求,要从路径中删除该节点,并从累加值中减去该结点的值
确保返回返回父节点时得到的路径刚好是从根节点到父节点的路径。
如果题目中要求在返回值的list中,数组长度大的数组靠前,就将最后生成的list中的各个数组按照数组的长度由大到小排序,
因为在递归方法中list中数组的添加顺序并不能保证一定是长度最长的先添加进list。
题目解答:
import java.util.*;
/**
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;
public TreeNode(int val) {
this.val = val;
}
}
*/
public class Solution {
public ArrayList<ArrayList<Integer>> FindPath(TreeNode root,int target) {
ArrayList<ArrayList<Integer>> res=new ArrayList<>();//返回的路径数组
ArrayList<Integer> cur=new ArrayList<>();
helper(root,target,cur,res);//cur为当前的路径
Collections.sort(res, new Comparator<ArrayList<Integer>>() {
@Override
public int compare(ArrayList<Integer> o1, ArrayList<Integer> o2) {
if (o1.size()<o2.size()){
return 1;
}else return -1;
}
});
return res;
}
public void helper(TreeNode root,int target,ArrayList<Integer> cur,ArrayList<ArrayList<Integer>> res){
if (root==null) return;
int value=root.val;
cur.add(value);
if (target==value && root.left==null && root.right==null){//目标值为当前值,且这个节点是叶子节点
res.add(new ArrayList<>(cur));
}else {
helper(root.left,target-value,cur,res);//递归循环左右子树
helper(root.right,target-value,cur,res);
}
cur.remove(cur.size()-1);//消除掉当前节点对查找路径的影响 --> 至关重要
}
}
Stay hungry,Stay foolish
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 【译】我们最喜欢的2024年的 Visual Studio 新功能
· 如何打造一个高并发系统?