二叉树中某种的路径

xiaoxiao2021-02-27  443

输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。

利用递归,但是有几点必须要注意

1:递归的停止条件是什么

    2:路径不只一条,当得到了一条路径后,怎么得到其他路径

import java.util.ArrayList; /** public class TreeNode { int val = 0; TreeNode left = null; TreeNode right = null; public TreeNode(int val) { this.val = val; } } */ public class Solution { ArrayList<ArrayList<Integer>> AArlist = new ArrayList<ArrayList<Integer>>(); ArrayList<Integer> array = new ArrayList<Integer>(); public ArrayList<ArrayList<Integer>> FindPath(TreeNode root,int target) { if(root==null) return AArlist; target= target - root.val; array.add(root.val); if(root.left==null && root.right==null && target==0) AArlist.add(new ArrayList<Integer>(array)); //将新建的这个丢进去,是为了防止array改变 //使得AArlist也发生改变 FindPath(root.left,target); FindPath(root.right,target); array.remove(array.size()-1);//应为array是全局变量,这个路径结束后,怎样让array返回成上一个路径 //的样子 return AArlist; } }

转载请注明原文地址: https://www.6miu.com/read-8375.html

最新回复(0)