給定一個數(shù)組,判斷其實否為二叉搜索樹的后序遍歷(Java)

實現(xiàn)的思想

后序遍歷的特點:根在最后輸出
二叉搜索樹的特點:根的值大于左子樹值鲁纠,小于右子樹值

算法實現(xiàn):
① 后序遍歷數(shù)組最后面的值為整棵樹的根root
② 遍歷數(shù)組找到當(dāng)前值比根root小并且后一個值大于根root的索引
③ 若數(shù)組為后續(xù)遍歷霍掺,則索引后面的值都應(yīng)該大于根root,若找到小于根root谎柄,則返回false
④ 若第③步不為false則遞歸的形參更新為左右子樹數(shù)組索引繼續(xù)重復(fù)②和③步驟。

public class Main   
{  
    public static void main(String[] args)  
    {  
        //int[] arr={5,7,6,9,11,10,8};  
        int[] arr={4,7,5,9,13,11,8}; 
       
        System.out.println(isProOfBST(arr,0, arr.length-1));  
    }  
    public static boolean isProOfBST(int[] arr,int left, int end)   
    {  
        if(arr == null || left > end)  return false;  
        int root = arr[end];//后序遍歷的最后一個為根節(jié)點  
        int i = left;  
        while(arr[i] < root && i < end)//找到左樹的個數(shù)  
            i++;  
        int j = i;//先看右樹中是否有非法數(shù)字惯雳,即比根節(jié)點小的數(shù)字  
        while(j < end)  
        {  
            if(arr[j] < root) return false;  
            j++;  
        }  
        if(i == end) return true;  //如果尋找結(jié)果發(fā)現(xiàn)最后只有左右葉子節(jié)點,則返回true
        return isProOfBST(arr, left, i-1) && isProOfBST(arr, i, end-1);
    }     
}  
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸿摇,一起剝皮案震驚了整個濱河市石景,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖潮孽,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件揪荣,死亡現(xiàn)場離奇詭異,居然都是意外死亡往史,警方通過查閱死者的電腦和手機仗颈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來椎例,“玉大人挨决,你說我怎么就攤上這事《┩幔” “怎么了脖祈?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長刷晋。 經(jīng)常有香客問我盖高,道長,這世上最難降的妖魔是什么眼虱? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任喻奥,我火速辦了婚禮,結(jié)果婚禮上捏悬,老公的妹妹穿的比我還像新娘撞蚕。我一直安慰自己,他們只是感情好邮破,可當(dāng)我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布诈豌。 她就那樣靜靜地躺著,像睡著了一般抒和。 火紅的嫁衣襯著肌膚如雪矫渔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天摧莽,我揣著相機與錄音庙洼,去河邊找鬼。 笑死镊辕,一個胖子當(dāng)著我的面吹牛油够,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播征懈,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼石咬,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了卖哎?” 一聲冷哼從身側(cè)響起鬼悠,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤删性,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后焕窝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蹬挺,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年它掂,在試婚紗的時候發(fā)現(xiàn)自己被綠了巴帮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡虐秋,死狀恐怖榕茧,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情熟妓,我是刑警寧澤雪猪,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站起愈,受9級特大地震影響只恨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜抬虽,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一官觅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧阐污,春花似錦休涤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至手幢,卻和暖如春捷凄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背围来。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工跺涤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人监透。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓桶错,卻偏偏與公主長得像,于是被迫代替她去往敵國和親胀蛮。 傳聞我的和親對象是個殘疾皇子院刁,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,933評論 2 355

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