镜像二叉树相关问题(通过此问题说明recursive的本质)

目前遇到两类题目:

(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里面有提到这个题)

这个递归和非递归也很简单,只要每个节点能遍历到,交换左右子树就可以了。

 

Symmetric Tree

剑指Offer-20-二叉树的镜像

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>