目前遇到两类题目:
(1)判断一个二叉树是否是镜像的,leetcode有相关题目。
可以用递归实现,也可以用非递归实现,思路都比较清晰
递归方法
判断一个二叉树是否是镜像的,就是判断二叉树的左右子树是否是镜像的。
递归中有两个问题需要回答:
base case(退出递归的条件):可以直接计算出结果,而不用进一步递归的case。两个节点都是null,return true。或者一个节点是null,return false。
recurence relation(递归关系):就是说子问题的递归结果,怎么解决最终问题的结果。 即最终问题的结果和子问题结果们的关系。对于这个问题而言,两节点的值是相同的,且node1.left和node2.right是镜像的,且node.right和node2.left镜像的。
private boolean helper(TreeNode node1, TreeNode node2) {
if (node1 == null && node2 == null) return true;
if (node1 == null || node2 == null) return false;
return (node1.val == node2.val) && helper(node1.left, node2.right) && helper(node1.right, node2.left);
}
非递归方法
本质上就是要遍历树,对应这道题来说,就是在遍历的过程中比较“镜像的节点”的值是不是一样。
遍历来说就有两种方案了,BFS和DFS,这道题两个遍历方案都行,因为只要能遍历到每个Node就行,而不关心先后。
DFS:
public boolean isSymmetric(TreeNode root) {
if (root == null) return true;
Stack<TreeNode> stack = new Stack();
Stack<TreeNode> stack2 = new Stack();
stack.push(root.right);
stack.push(root.left);
while (!stack.isEmpty()) {
TreeNode node1 = stack.pop();
TreeNode node2 = stack.pop();
if (node1 == null && node2 == null) continue;
if (node1 == null || node2 == null) return false;
if (node1.val != node2.val) return false;
stack.push(node1.left);
stack.push(node2.right);
stack.push(node1.right);
stack.push(node2.left);
}
return true;
}
BFS
大家自己写吧
(2)对一个二叉树进行镜像 (剑指offer里面有提到这个题)
这个递归和非递归也很简单,只要每个节点能遍历到,交换左右子树就可以了。