题目链接:https://leetcode-cn.com/problems/binary-tree-inorder-traversal/
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { public List<Integer> inorderTraversal(TreeNode root) { List<Integer> res = new ArrayList<Integer>(); inorder(root, res); return res; } public void inorder(TreeNode root, List<Integer> res){ if(root == null){ return; } inorder(root.left, res); res.add(root.val); inorder(root.right, res); } }
注意点:
- 先序遍历【根->左孩子->右孩子】,中序遍历【左孩子->根->右孩子】,后序遍历【左孩子->右孩子->根】 的思路【这里的序指的是根的顺序】
- 写的时候抽出单独的方法,不然返回值不太好返回。