题解 | #二叉树的镜像#

二叉树的镜像

http://www.nowcoder.com/practice/a9d0ecbacef9410ca97463e4a5c83be7

思路其实很简单,采用的递归。
既然是递归,我就分成两个部分来说:1、递归主体 2、终止条件
1、递归主体,这里就是让左右的两部分子节点互换
2、需要考虑节点本身是null,左右节点都是null,左右节点有一个是null三种情况。前两种情况直接终止程序,最后一种情况正常进行递归主体操作。

public TreeNode Mirror (TreeNode pRoot) {
    // write code here
    if(pRoot == null || (pRoot.left == null && pRoot.right == null)){
        return pRoot;
    }

    TreeNode temp = pRoot.left;
    pRoot.left = pRoot.right;
    pRoot.right = temp;
    Mirror(pRoot.left);
    Mirror(pRoot.right);
    return pRoot;
}

}

全部评论

相关推荐

04-15 09:59
门头沟学院 C++
yy_11:小公司人家没必要泄密,大公司都是本地部署了
你想吐槽公司的哪些规定
点赞 评论 收藏
分享
求好运眷顾🙏🏻:翻译:面试前没盘点好hc一下面太多了,现在在排序回去等通知
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务