Leetcode 98. Validate Binary Search Tree

原題地址:https://leetcode.com/problems/validate-binary-search-tree/description/

題目描述

Given a binary tree, determine if it is a valid binary search tree (BST).
Assume a BST is defined as follows:

  • The left subtree of a node contains only nodes with keys less than the node's key.
  • The right subtree of a node contains only nodes with keys greater than the node's key.
  • Both the left and right subtrees must also be binary search trees.

例子就不貼了纬傲。就是要判斷一棵二叉樹是不是有效的搜索樹满败,即左子節(jié)點(diǎn)的值小于父節(jié)點(diǎn)的值,右子節(jié)點(diǎn)的值大于父節(jié)點(diǎn)的值叹括。

思路

一開始我寫了一個(gè)DFS,在遍歷的時(shí)候檢查每單個(gè)父節(jié)點(diǎn)和它的兩個(gè)子節(jié)點(diǎn)的大小關(guān)系宵荒,但是即便每個(gè)父節(jié)點(diǎn)都符合這樣的檢查條件仍然可能是無效的搜索樹汁雷,如圖


失敗樣例.png

元素6這個(gè)節(jié)點(diǎn)就不該出現(xiàn)在右邊的子樹上净嘀,因?yàn)?小于10。
之后我的做法是侠讯,對(duì)符合題目條件的有效搜索樹進(jìn)行中序遍歷挖藏,判斷所得到的數(shù)組是不是已經(jīng)有序了(遞增)。如果是則返回true厢漩,不是則返回false膜眠。

代碼

/**
 * 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:
    vector<int> result;
    void travelInorder(TreeNode* root){
        if(root!=NULL){
            travelInorder(root->left);
            result.push_back(root->val);
            travelInorder(root->right);
        }
    }
    
    bool isValidBST(TreeNode* root) {
        if(root==NULL){
            return true;
        }
        travelInorder(root);
        for(int i =0 ;i<result.size()-1;i++){
            if(result[i]>=result[i+1]){
                return false;
            }
        }
        return true;
    }
};

運(yùn)行時(shí)間擊敗了%39.21的人。

踩坑

要注意的地方就是出現(xiàn)相等的元素算無效搜索樹溜嗜,以及輸入可能為空宵膨。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市炸宵,隨后出現(xiàn)的幾起案子辟躏,更是在濱河造成了極大的恐慌,老刑警劉巖土全,帶你破解...
    沈念sama閱讀 222,627評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件捎琐,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡裹匙,警方通過查閱死者的電腦和手機(jī)瑞凑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來概页,“玉大人籽御,你說我怎么就攤上這事〈铝ぃ” “怎么了篱蝇?”我有些...
    開封第一講書人閱讀 169,346評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)徽曲。 經(jīng)常有香客問我零截,道長(zhǎng),這世上最難降的妖魔是什么秃臣? 我笑而不...
    開封第一講書人閱讀 60,097評(píng)論 1 300
  • 正文 為了忘掉前任涧衙,我火速辦了婚禮,結(jié)果婚禮上奥此,老公的妹妹穿的比我還像新娘弧哎。我一直安慰自己,他們只是感情好稚虎,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評(píng)論 6 398
  • 文/花漫 我一把揭開白布撤嫩。 她就那樣靜靜地躺著,像睡著了一般蠢终。 火紅的嫁衣襯著肌膚如雪序攘。 梳的紋絲不亂的頭發(fā)上酒唉,一...
    開封第一講書人閱讀 52,696評(píng)論 1 312
  • 那天西潘,我揣著相機(jī)與錄音桌粉,去河邊找鬼旦袋。 笑死,一個(gè)胖子當(dāng)著我的面吹牛瞄沙,可吹牛的內(nèi)容都是我干的己沛。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼距境,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼申尼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起肮疗,我...
    開封第一講書人閱讀 40,108評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤晶姊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后伪货,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體们衙,經(jīng)...
    沈念sama閱讀 46,646評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評(píng)論 3 342
  • 正文 我和宋清朗相戀三年碱呼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蒙挑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,861評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡愚臀,死狀恐怖忆蚀,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情姑裂,我是刑警寧澤馋袜,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站舶斧,受9級(jí)特大地震影響欣鳖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜茴厉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評(píng)論 3 336
  • 文/蒙蒙 一泽台、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧矾缓,春花似錦怀酷、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春笔横,著一層夾襖步出監(jiān)牢的瞬間竞滓,已是汗流浹背咐吼。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評(píng)論 1 274
  • 我被黑心中介騙來泰國打工吹缔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人锯茄。 一個(gè)月前我還...
    沈念sama閱讀 49,287評(píng)論 3 379
  • 正文 我出身青樓厢塘,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親肌幽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子晚碾,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評(píng)論 2 361

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