二种方法:STACK和递归调用

二叉树的镜像

http://www.nowcoder.com/questionTerminal/564f4c26aa584921bc75623e48ca3011

碰到节点就swap(left,right)就完事了,然后在选择一种遍历方法 入栈的或者递归的:前中后序遍历方法。参考:二叉树:层序,前,中,后 序遍历的解题模板https://blog.csdn.net/sinat_36338365/article/details/107916628

class Solution {
public:
    void Mirror(TreeNode *pRoot) {
        if(pRoot==NULL)return ;//如果节点为空则返回
        TreeNode *p=pRoot;
//方法一:stack
        /*stack<TreeNode*>sta;//前序(中后都行)遍历每个节点,然后交换他们的左右节点
        sta.push(p);
        while(!sta.empty()){
            TreeNode *temp=sta.top();
            sta.pop();
            swap(temp->left,temp->right);//将节点的左右子树进行交换
            if(temp->left)    sta.push(temp->left);
            if(temp->right)   sta.push(temp->right);
        }*/
//方法二:递归调用,每次都把根节点的左右子树交换 知道节点为NULL
        swap(p->left,p->right);
        Mirror( p->left);
        Mirror( p->right);
    }
};
全部评论

相关推荐

2024-12-22 19:38
已编辑
黄冈师范学院 后端
寿命齿轮:实习就一段还拉了,项目一看就不是手搓,学历也拉了,技术栈看着倒是挺好,就是不知道面试表现能咋样。 不过现在才大三,争取搞两端大厂实习,或者一个纯个人项目+一段大厂,感觉秋招还是未来可期。
投递美团等公司8个岗位
点赞 评论 收藏
分享
2024-12-18 12:05
华东师范大学 golang
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务