Subtree of Another Tree (Leetcode 572)

在這里給出兩種做法,

第一種是直接搜索,O(n * m) 的worse case,

class Solution {
public:
    
    bool isSameTree(TreeNode* x, TreeNode* y){
        if(x == NULL && y == NULL) return true;
        else if(x == NULL || y == NULL) return false;
        if(x->val != y->val) return false;
        return isSameTree(x->left, y->left) && isSameTree(x->right, y->right);
    }

    bool isSubtree(TreeNode* s, TreeNode* t) {
        if(s == NULL && t == NULL) return true;
        else if(s == NULL || t == NULL) return false;
        if(isSameTree(s, t)) return true;
        return isSubtree(s->left, t) || isSubtree(s->right, t);
    }
};

第二種參考網上的思路,把樹轉化成string,然后再用find substring的辦法。不過庫函數的find substring一般也不用kmp,而是直接一個一個的搜索查找,所以復雜度也是 O(n * m) 級別. 兩種方法leetcode runtime差不多

class Solution {
public:

    void serialize(TreeNode* root, string &s){
        if(root){
            s += '(' + to_string(root->val) + ')';
            s += ' ';
            serialize(root->left, s);
            serialize(root->right, s);
        }else{
            s += '#' + ' ';
        }
    }

    bool isSubtree(TreeNode* s, TreeNode* t) {
        if(!s && !t) return true;
        else if(!s || !t) return false;
        string s_string, t_string;
        serialize(s, s_string);
        serialize(t, t_string);
        return s_string.find(t_string) != string::npos;
    }
};
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 背景 一年多以前我在知乎上答了有關LeetCode的問題, 分享了一些自己做題目的經驗。 張土汪:刷leetcod...
    土汪閱讀 12,769評論 0 33
  • LeetCode 刷題隨手記 - 第一部分 前 256 題(非會員),僅算法題,的吐槽 https://leetc...
    蕾娜漢默閱讀 17,922評論 2 36
  • 僅僅開班四天,我就已經三次沒有交作業了,違規次數已經用完,今早給組長留言要求退出,組長告知第四次違規才可會退群,鼓...
    瀟湘2016閱讀 235評論 0 0
  • 跌倒并不可怕,可怕的是跌倒后再也站不起來。 一生中我們總會遇到大大小小的許多事情,有成功也會有失敗。上學的時候,最...
    周詩汶閱讀 495評論 0 2