Tree

Binary Tree Inorder Traversal

Link: https://leetcode.com/problems/binary-tree-inorder-traversal/

Code:

/**
 * 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<>();
        treeTraversal(root, res);
        return res;
    }
    
    public void treeTraversal(TreeNode root, List<Integer> res) {
        if (root != null) {
            treeTraversal(root.left, res);
            res.add(root.val);
            treeTraversal(root.right, res);
        }
    }
}
  • inorder traversal: left, root, right;

  • preorder traversal: root, left, right;

  • postorder traversal: left, right, root;

  • add() method for List;

Unique Binary Search Trees

Link: https://leetcode.com/problems/unique-binary-search-trees/

Code:

  • Dynamic programming;

  • G[i] is the number of unique BSTs with i nodes;

  • Base case: G[0] = 1, G[1] = 1;

  • Recursive case: G[i] = G[0] * G[i-1] + G[1] * G[i-2] + ... + G[i-1] * G[0];

Last updated