leetcode971. Flip Binary Tree To Match Preorder Traversal

题目:给定一个有 N 个节点的二叉树,每个节点都有一个不同于其他节点且处于 {1, …, N} 中的值。
通过交换节点的左子节点和右子节点,可以翻转该二叉树中的节点。
考虑从根节点开始的先序遍历报告的 N 值序列。将这一 N 值序列称为树的行程。
(回想一下,节点的先序遍历意味着我们报告当前节点的值,然后先序遍历左子节点,再先序遍历右子节点。)
我们的目标是翻转最少的树中节点,以便树的行程与给定的行程 voyage 相匹配。
如果可以,则返回翻转的所有节点的值的列表。你可以按任何顺序返回答案。
如果不能,则返回列表 [-1]。

leetcode971. Flip Binary Tree To Match Preorder Traversal
参考
别人思路: 若当前节点为空,返回True;若当前节点不等于目标值,返回False;若当前节点的左孩子不为空且不等于目标值,则反转。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    int i = 0;
    ArrayList list = new ArrayList<>();
    public List<Integer> flipMatchVoyage(TreeNode root, int[] voyage) {
        return dfs(root, voyage) ? list : Arrays.asList(-1);
    }
    public Boolean dfs(TreeNode root, int v[]){
        if(root == null){
            return true;
        }
        if(root.val != v[i++]){
            return false;
        }
        if(root.left != null && root.left.val != v[i]){
            list.add(root.val);
            return dfs(root.right, v) && dfs(root.left, v);
        }
        return dfs(root.left, v) && dfs(root.right, v);
    }
}