栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

101.对称二叉树

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

101.对称二叉树

给定一个二叉树,检查它是否是镜像对称的。

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

1

/
2 2
/ /
3 4 4 3

但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

1

/
2 2

3 3


方法1

根左右遍历一次树得到数组,根右左遍历一次得到数组
对比,相等则对称
存在根左右与根右左相等的子树,便使用某个数来标记全部空结点防止出现这种情况

class Solution {
public:
    void leorder(TreeNode*root,vector &arrleft)
    {
        if(!root){arrleft.push_back(-1);return;}
        arrleft.push_back(root->val);
        leorder(root->left,arrleft);
        leorder(root->right,arrleft);

    }
    void riorder(TreeNode*root,vector &arrright)
    {
        if(!root){arrright.push_back(-1);return;}
        arrright.push_back(root->val);
        riorder(root->right,arrright);
        riorder(root->left,arrright);

    }
    bool isSymmetric(TreeNode* root) {
        vectorarrleft;
        vectorarrright;
        leorder(root,arrleft);
        riorder(root,arrright);
        if(arrleft==arrright)return 1;
        else return 0;


    }
};

当然,这个方法不够聪明


方法二:

使用两个指针分部从左边右边遍历即可,使用原理为递归

class Solution {
public:
    bool check(TreeNode*p,TreeNode* q)
    {
        if(!q&&!p)return true;
        if(!p||!q)return false;
        return (p->val==q->val)
        &&check(p->left,q->right)
        &&check(p->right,q->left);
    }

    bool isSymmetric(TreeNode* root) {
        return check(root,root);
    }
};
方法三:

利用队列,类似于层序遍历来迭代它,也可以说是广度搜索(或许

class Solution {
public:
    bool check(TreeNode* u,TreeNode* v)
    {
        queueque;
        que.push(u);que.push(v);
        while(!que.empty())
        {  u=que.front();que.pop();
           v=que.front();que.pop();
        if(!u&&!v)continue;
        if((!u||!v)||u->val!=v->val)return false;
        que.push(u->left);
        que.push(v->right);

        que.push(u->right);
        que.push(v->left);

        }
        return true;
    }
    bool isSymmetric(TreeNode* root) {
        return check(root,root);

    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/513031.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号