【剑指offer】对称的二叉树

题目描述

请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。

分析:从上到下直接遍历,利用栈或者队列暂存结点,注意结点的存和取都是成对的

复制代码
class Solution
{
public:
    bool isSymmetrical(TreeNode* root)
    {
        if(root==NULL)
            return true;
        stack<TreeNode*> s;
        s.push(root->left);
        s.push(root->right);

        while(s.size()!=0)
        {
            TreeNode *left=s.top();
            s.pop();
            TreeNode *right=s.top();
            s.pop();

            if(left==NULL&&right==NULL)
                continue;
            if(left==NULL&&right!=NULL)
                return false;
            if(left!=NULL&&right==NULL)
                return false;
            if(left->val!=right->val)//值不相等肯定不是镜像
                return false;
                
            //左子树的左孩子和右子树的有孩子是一对
            s.push(left->left);
            s.push(right->right);
            
            //左子树的右孩子和右子树的左孩子是一对
            s.push(left->right);
            s.push(right->left);
        }
        return true;
    }
};
复制代码
posted @   西*风  阅读(154)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示