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使用html2canvas实现页面截图并保存图片
    微信小程序之图片base64解码
    微信小程序之回调函数
    小程序横向滚动
    搭建vue开发环境的步骤
    检测算法简介及其原理——fast R-CNN,faster R-CNN,YOLO,SSD,YOLOv2,YOLOv3
    hadoop常用命令
    工作流调度系统Azkaban的简介和使用
    java微服务简介与实战
    mxnet快速入门教程
  • 原文地址:https://www.cnblogs.com/ganganloveu/p/4136259.html
Copyright © 2011-2022 走看看