zoukankan      html  css  js  c++  java
  • 【LeetCode】100. Same Tree (2 solutions)

    Same Tree

    Given two binary trees, write a function to check if they are equal or not.

    Two binary trees are considered equal if they are structurally identical and the nodes have the same value.

    解法一:递归

    /**
     * Definition for binary tree
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        bool isSameTree(TreeNode *p, TreeNode *q) {
            if(!p && !q)
                return true;
            else if(!p && q)
                return false;
            else if(p && !q)
                return false;
            else
            {
                if(p->val != q->val)
                    return false;
                else
                    return isSameTree(p->left, q->left) && isSameTree(p->right, q->right);
            }
        }
    };

    解法二:非递归

    建立两个队列分别进行层次遍历,进队时检查对应点是否相等

    /**
     * Definition for binary tree
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        bool isSameTree(TreeNode *p, TreeNode *q) {
            if(!isSameNode(p, q))
                return false;
            if(!p && !q)
                return true;
            
            queue<TreeNode*> lqueue;
            queue<TreeNode*> rqueue;
            lqueue.push(p);
            rqueue.push(q);
            while(!lqueue.empty() && !rqueue.empty())
            {
                TreeNode* lfront = lqueue.front();
                TreeNode* rfront = rqueue.front();
    
                lqueue.pop();
                rqueue.pop();
                
                if(!isSameNode(lfront->left, rfront->left))
                    return false;
                if(lfront->left && rfront->left)
                {
                    lqueue.push(lfront->left);
                    rqueue.push(rfront->left);
                }
                
                if(!isSameNode(lfront->right, rfront->right))
                    return false;
                if(lfront->right && rfront->right)
                {
                    lqueue.push(lfront->right);
                    rqueue.push(rfront->right);
                }
            }
            return true;
        }
        bool isSameNode(TreeNode* p, TreeNode *q)
        {
            if(!p && !q)
                return true;
            if((p && !q) || (!p && q) || (p->val != q->val))
                return false;
            return true;
        }
    };

  • 相关阅读:
    js 匿名函数的链式调用
    mysql 数据库操作的一般操作命令
    js 截取一定数量的字节
    js 截取10个字节
    BootStrap入门教程 (四)
    安装Dedecms遇到的一系列问题
    BootStrap入门教程 (三)
    dedecms标签调用大全
    artDialog皮肤引入方式
    织梦cms安装完成后登录后台出现空白。主要原因是php版本的问题
  • 原文地址:https://www.cnblogs.com/ganganloveu/p/4136259.html
Copyright © 2011-2022 走看看