-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathBinaryTreePaths.java
47 lines (42 loc) · 2.62 KB
/
BinaryTreePaths.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
/*
* 输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。
* 路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前)
* */
public class BinaryTreePaths {
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;
public TreeNode(int val) {
this.val = val;
}
}
private ArrayList<ArrayList<Integer>> result = new ArrayList<ArrayList<Integer>>(); //结果列表,存放以列表为格式的多条路径
private ArrayList<Integer> list = new ArrayList<Integer>(); //路径所经过节点的值依次保存在一条路径列表中
public ArrayList<ArrayList<Integer>> findPath(TreeNode root, int target) {
getPath(root, target); //获取经过路径的一至多个列表
Collections.sort(result, new Comparator<ArrayList<Integer>>() {
@Override
public int compare(ArrayList<Integer> l1, ArrayList<Integer> l2) { //将多条路径按长度排序,大的排在前面
return l2.size() - l1.size();
}
});
return result; //获取包含多条路径的结果列表
}
private void getPath(TreeNode root, int target) {
if (root == null) return;
list.add(root.val); //在代表所经过路径的列表中加入当前根节点
target -= root.val; //路径列表加入当前根节点后,求和的值减去已经算在路径中的节点的值
if (target == 0 && root.left == null && root.right == null) {
//当二叉树路径遍历完下面再也没有节点,并且路径所经过节点的值的和正好等于输入的整数时,重新用一个新的列表存放这一条路径,以免和公用的list混淆
result.add(new ArrayList<Integer>(list));
}
getPath(root.left, target); //递归从当前根节点的左子树继续遍历路径,看看是否经过的值的和能等于输入的整数
getPath(root.right, target); //递归从当前根节点的右子树继续遍历路径,看看是否经过的值的和能等于输入的整数
//存放经过路径的列表移除最后存放的值,即经过的最后一个节点,这样路径就能回退一个节点到自己的父节点上,层层递归后就能回退到一开始的根节点上,能够继续往下遍历另一条路径
list.remove(list.size() - 1);
}
}