二叉樹(shù)題目

LCA
https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-tree
https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-search-tree/
https://leetcode.com/problems/flatten-binary-tree-to-linked-list/
https://leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/
https://leetcode.com/problems/validate-binary-search-tree/

普通二叉樹(shù):
自下向上的解法
我覺(jué)得應(yīng)該再加一層吼和,先檢查p沫勿,q是不是都在樹(shù)上。

class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(!root) return NULL;
        if(root == p || root == q) return root;
        TreeNode * left = lowestCommonAncestor(root->left, p, q);
        TreeNode * right = lowestCommonAncestor(root->right, p, q);
        if(left && right) return root;
        if(!left && right) return right;
        if(left && !right) return left;
        return NULL;
    }
};

以上方法無(wú)法在不存在的時(shí)候返回空西轩。

自上向下的解法铣缠,平衡情況 O(n)揭糕,最壞情況O(n^2):
但其實(shí)這個(gè)也沒(méi)有檢查是否是否兩個(gè)節(jié)點(diǎn)都出現(xiàn)在樹(shù)上柱蟀。
http://articles.leetcode.com/lowest-common-ancestor-of-a-binary-tree-part-i/

// Return #nodes that matches P or Q in the subtree.
int countMatchesPQ(Node *root, Node *p, Node *q) {
  if (!root) return 0;
  int matches = countMatchesPQ(root->left, p, q) + countMatchesPQ(root->right, p, q);
  if (root == p || root == q)
    return 1 + matches;
  else
    return matches;
}
 
Node *LCA(Node *root, Node *p, Node *q) {
  if (!root || !p || !q) return NULL;
  if (root == p || root == q) return root;
  int totalMatches = countMatchesPQ(root->left, p, q);
  if (totalMatches == 1)
    return root;
  else if (totalMatches == 2)
    return LCA(root->left, p, q);
  else /* totalMatches == 0 */
    return LCA(root->right, p, q);
}    

非遞歸方法,注意最后路徑分叉和包含問(wèn)題贡翘。

class Solution {
    
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* t1, TreeNode* t2) {
        if(!root || !t1 || !t2) return NULL;
        int num = 0;
        vector<TreeNode *> st;
        TreeNode * p = root;
        TreeNode * pre = NULL;
        vector<TreeNode *> path1, path2;
        while(!st.empty() || p!=NULL) {
            if(p!=NULL) {
                st.push_back(p);
                if(p == t1) {
                    path1 = st;
                }
                if(p == t2) {
                    path2 = st;
                }
                p = p->left;
            } else {
                TreeNode * n = st.back(); 
                if(n->right != pre && n->right != NULL){
                    p = n->right;
                } else {
                    st.pop_back();
                    pre = n;
                }
            }
        }
        
        int m = min(path1.size(), path2.size());
        int i;
        for(i = 0; i < m; i++) {
            if(path1[i] != path2[i] && i > 0) {
                return path1[i-1];
            }
        }
        if(i == m) {
            return path1[i-1];
        }
        return NULL;
    }
};

BST的相似題目:

class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(p->val > q->val) {
            swap(p,q);
        }
        if(root->val >= p->val && root->val <= q->val) {
            return root;
        }
        if(root->val > q->val) {
            return lowestCommonAncestor(root->left,p,q);
        }
        if(root->val < p->val) {
            return lowestCommonAncestor(root->right,p,q);
        }
    }
};

iterative:
https://leetcode.com/discuss/45511/easy-c-recursive-and-iterative-solutions

class Solution { 
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        TreeNode* cur = root;
        while (true) {
            if (p -> val < cur -> val && q -> val < cur -> val)
                cur = cur -> left;
            else if (p -> val > cur -> val && q -> val > cur -> val)
                cur = cur -> right;
            else return cur; 
        }
    }
};    

把Binary Tree拉成串
Flatten Binary Tree to Linked List

class Solution {
    TreeNode * helper(TreeNode * root) {
        if(root == NULL) return NULL;
        if(!root->left && !root->right) { return root;}
        TreeNode * ltail = helper(root->left);
        TreeNode * rhead = root->right;
        if(root->left) {
            root->right = root->left;
            root->left = NULL;
            ltail->right = rhead;
        }
        TreeNode * rtail = helper(root->right);
        return rtail;
    }
public:
    void flatten(TreeNode* root) {
        if(root == NULL) return;
        helper(root);
    }
};

106.Construct Binary Tree from Inorder and Postorder Traversal

class Solution {
    TreeNode * helper(vector<int>& inorder, vector<int>& postorder, int ii, int ij, int pi, int pj) {
        if(ii > ij || pi > pj) {
            return NULL;
        }
        TreeNode * root = new TreeNode(postorder[pj]);
        int mid;
        for(int i = ii; i <= ij; i++) {
            if(inorder[i] == postorder[pj]) {
                mid = i;
                break;
            }
        }
        int leftlen = mid - ii;
        int rightlen = ij - mid;
        TreeNode * l = helper(inorder, postorder, ii, mid - 1, pi, pi+ leftlen - 1);
        TreeNode * r = helper(inorder, postorder, mid + 1, ij, pi + leftlen, pj - 1);
        root->left = l;
        root->right = r;
        return root;
    }
public:
    TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder) {
        int n = inorder.size();
        return helper(inorder,postorder, 0, n-1, 0, n-1);
    }
};

98.Validate Binary Search Tree

class Solution {
    bool helper(TreeNode * root, TreeNode * smallest, TreeNode * largest) {
        if(root == NULL) {return true;}
        if(smallest) {
            if(root->val <= smallest->val) {return false;}
        }
        if(largest) {
            if(root->val >= largest->val) {return false;}
        }
        return helper(root->left,smallest,root) && helper(root->right, root, largest);
    }
public:
    bool isValidBST(TreeNode* root) {
        return helper(root,NULL,NULL);
    }
};

inorder遍歷
https://leetcode.com/discuss/14886/order-traversal-please-rely-buggy-int_max-int_min-solutions

class Solution {
public:
    bool isValidBST(TreeNode* root) {
        TreeNode* prev = NULL;
        return validate(root, prev);
    }
    bool validate(TreeNode* node, TreeNode* &prev) {
        if (node == NULL) return true;
        if (!validate(node->left, prev)) return false;
        if (prev != NULL && prev->val >= node->val) return false;
        prev = node;
        return validate(node->right, prev);
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蹈矮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子鸣驱,更是在濱河造成了極大的恐慌泛鸟,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件踊东,死亡現(xiàn)場(chǎng)離奇詭異谈况,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)递胧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)赡茸,“玉大人缎脾,你說(shuō)我怎么就攤上這事≌嘉裕” “怎么了遗菠?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,386評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵联喘,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我辙纬,道長(zhǎng)豁遭,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,726評(píng)論 1 297
  • 正文 為了忘掉前任贺拣,我火速辦了婚禮蓖谢,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘譬涡。我一直安慰自己闪幽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布涡匀。 她就那樣靜靜地躺著盯腌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪陨瘩。 梳的紋絲不亂的頭發(fā)上腕够,一...
    開(kāi)封第一講書(shū)人閱讀 52,337評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音舌劳,去河邊找鬼帚湘。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蒿囤,可吹牛的內(nèi)容都是我干的客们。 我是一名探鬼主播,決...
    沈念sama閱讀 40,902評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼材诽,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼底挫!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起脸侥,我...
    開(kāi)封第一講書(shū)人閱讀 39,807評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤建邓,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后睁枕,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體官边,經(jīng)...
    沈念sama閱讀 46,349評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評(píng)論 3 340
  • 正文 我和宋清朗相戀三年外遇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了注簿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,567評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡跳仿,死狀恐怖诡渴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情菲语,我是刑警寧澤妄辩,帶...
    沈念sama閱讀 36,242評(píng)論 5 350
  • 正文 年R本政府宣布惑灵,位于F島的核電站,受9級(jí)特大地震影響眼耀,放射性物質(zhì)發(fā)生泄漏英支。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評(píng)論 3 334
  • 文/蒙蒙 一哮伟、第九天 我趴在偏房一處隱蔽的房頂上張望干花。 院中可真熱鬧,春花似錦澈吨、人聲如沸把敢。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,420評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)修赞。三九已至,卻和暖如春桑阶,著一層夾襖步出監(jiān)牢的瞬間柏副,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,531評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工蚣录, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留割择,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,995評(píng)論 3 377
  • 正文 我出身青樓萎河,卻偏偏與公主長(zhǎng)得像荔泳,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子虐杯,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容