题解 | #二叉树的镜像#

二叉树的镜像

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;
}

}

全部评论

相关推荐

01-04 07:53
门头沟学院 C++
心愿便利贴:工作了以后回头再看待这个问题,从客观的视角来讲是因为每个人对自己的要求不同,学习好的人对自己的要求很高,所以觉得考不好就天塌了,认为自己学习好并且值得一份好工作的人也是一样,找不到符合自己预期的工作肯定也会觉得是侮辱,牛客上有很多名校大学生,肯定会存在这种好学生心态啊,“做题区”从来都不是贬义词,这是大部分普通人赖以生存的路径,这个有什么好嘲讽的,有“好学生心态”没有错,但是不要给自己太大的压力了
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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