static List<Integer> list = new ArrayList<>();
//前序遍历
public static List<Integer> preorderTraversal(TreeNode root) {
if(root == null)
{
return null;
}
list.add(root.val);
preorderTraversal(root.left);
preorderTraversal(root.right);
return list;
}
static List<Integer> list = new ArrayList<>();
//中序遍历
public static List<Integer> midorderTraversal(TreeNode root) {
if(root == null)
{
return null;
}
midorderTraversal(root.left);
list.add(root.val);
midorderTraversal(root.right);
return list;
}
public static List<Integer> BhorderTraversal(TreeNode root) {
if(root == null)
{
return null;
}
BhorderTraversal(root.left);
BhorderTraversal(root.right);
list.add(root.val);
return list;
}
其实这三个遍历差不多,只是list的添加元素的代码位置不一样
所谓的前序,中序,后序就是中间节点的位置