• 572. Subtree of Another Tree


    https://leetcode.com/problems/subtree-of-another-tree/description/

    easy 题也不easy,坑还是多。主要观察两个例子:[1,1] [1] 和 [3,4,5,1,null,null,2] [3,1,2]

    第一个例子主要考察当s, t 的val 都一样时,还是有两个情况:1. s 和 t 一模一样,2.t 是s 的子树。我就是把这一点忽略了。

    第二个例子是考察检查s,t 是否是一样时的逻辑。

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        bool sameTree(TreeNode* a, TreeNode* b) {
            if (a == nullptr && b == nullptr) return true;
            if (a == nullptr || b == nullptr) return false;
            if (a->val != b->val) return false;
            return sameTree(a->left, b->left) && sameTree(a->right, b->right);
        }
        bool isSubtree(TreeNode* s, TreeNode* t) {
            if (s == nullptr && t == nullptr) {return true;}
            if (s == nullptr || t == nullptr) {return false;}
            
            if (s->val == t->val) {
                return (sameTree(s->left, t->left) && sameTree(s->right, t->right)) || 
                    (isSubtree(s->left, t) || isSubtree(s->right, t));
            }
            
            return isSubtree(s->left, t) || isSubtree(s->right, t);
        }
    };
  • 相关阅读:
    苹果审核被拒,Guideline 1.1.6
    Java基础:类与继承
    Java中的static关键字解析
    Entity Framework 预备知识
    Entity Framework Code First执行SQL语句、视图及存储过程
    java多线程技能
    流与文件
    多线程
    集合
    断言
  • 原文地址:https://www.cnblogs.com/agentgamer/p/9779234.html
Copyright © 2020-2023  润新知