依旧还是层次遍历, 按层入队, 然后出队时, 交换左右节点
public static void flipTree(TreeNode node) { if (node == null) { return; } Queue<TreeNode> queue = new LinkedList<>(); queue.add(node); while (!queue.isEmpty()) { TreeNode n = queue.poll(); if (n.left != null) { queue.add(n.left); } if (n.right != null) { queue.add(n.right); } TreeNode left = n.left; TreeNode right = n.right; n.left = right; n.right = left; } }