通關(guān)劍指 Offer——?jiǎng)χ?Offer II 055. 二叉搜索樹(shù)迭代器

1.題目描述

劍指 Offer II 055. 二叉搜索樹(shù)迭代器

實(shí)現(xiàn)一個(gè)二叉搜索樹(shù)迭代器類(lèi)BSTIterator 懈凹,表示一個(gè)按中序遍歷二叉搜索樹(shù)(BST)的迭代器:

BSTIterator(TreeNode root) 初始化 BSTIterator 類(lèi)的一個(gè)對(duì)象惫企。BST 的根節(jié)點(diǎn) root 會(huì)作為構(gòu)造函數(shù)的一部分給出嫉称。指針應(yīng)初始化為一個(gè)不存在于 BST 中的數(shù)字,且該數(shù)字小于 BST 中的任何元素。
boolean hasNext() 如果向指針右側(cè)遍歷存在數(shù)字,則返回 true ;否則返回 false 泊交。
int next()將指針向右移動(dòng),然后返回指針處的數(shù)字柱查。
注意廓俭,指針初始化為一個(gè)不存在于 BST 中的數(shù)字,所以對(duì) next() 的首次調(diào)用將返回 BST 中的最小元素唉工。

可以假設(shè) next() 調(diào)用總是有效的研乒,也就是說(shuō),當(dāng)調(diào)用 next() 時(shí)淋硝,BST 的中序遍歷中至少存在一個(gè)下一個(gè)數(shù)字雹熬。

示例:

輸入
inputs = ["BSTIterator", "next", "next", "hasNext", "next", "hasNext", "next", "hasNext", "next", "hasNext"]
inputs = [[[7, 3, 15, null, null, 9, 20]], [], [], [], [], [], [], [], [], []]
輸出
[null, 3, 7, true, 9, true, 15, true, 20, false]

解釋
BSTIterator bSTIterator = new BSTIterator([7, 3, 15, null, null, 9, 20]);
bSTIterator.next();    // 返回 3
bSTIterator.next();    // 返回 7
bSTIterator.hasNext(); // 返回 True
bSTIterator.next();    // 返回 9
bSTIterator.hasNext(); // 返回 True
bSTIterator.next();    // 返回 15
bSTIterator.hasNext(); // 返回 True
bSTIterator.next();    // 返回 20
bSTIterator.hasNext(); // 返回 False

2.解題思路與代碼

2.1 解題思路

編寫(xiě)一個(gè)二叉搜索樹(shù)的迭代器,使迭代器按照從小到大的順序返回節(jié)點(diǎn)值谣膳。我們知道二叉搜索樹(shù)的中序遍歷得到的結(jié)果就是從小到大以此遞增的竿报,可以利用這一特性來(lái)完成題目。首先我們構(gòu)建一個(gè)列表 list 存放二叉搜索樹(shù)中序遍歷經(jīng)過(guò)的節(jié)點(diǎn)继谚,然后在構(gòu)造方法中對(duì)該二叉搜索樹(shù)進(jìn)行中序遍歷烈菌,并放入列表 list 中。

List<TreeNode> list;
int index = -1;

public BSTIterator(TreeNode root) {
  list = new ArrayList<>();
  process(root);
}

public void process(TreeNode node) {
  if (node == null) {
    return;
  }
  process(node.left);
  list.add(node);
  process(node.right);
}

這里還需要一個(gè) index 變量來(lái)遍歷該列表花履,以模擬迭代器芽世。我們需要完成迭代器的 next() 和 hasNext() 兩個(gè)方法,next() 方法要獲取 index 角標(biāo)的下一位元素诡壁,即 list.get(++index)济瓢,而 hasNext 方法直接判斷 index+1 是否小于列表長(zhǎng)度即可。

public int next() {
  return list.get(++index).val;
}

public boolean hasNext() {
  return index + 1 < list.size();
}

2.2 代碼


class BSTIterator {

    List<TreeNode> list;
    int index = -1;

    public BSTIterator(TreeNode root) {
        list = new ArrayList<>();
        process(root);
    }

    public void process(TreeNode node) {
        if (node == null) {
            return;
        }
        process(node.left);
        list.add(node);
        process(node.right);
    }

    public int next() {
        return list.get(++index).val;
    }

    public boolean hasNext() {
        return index + 1 < list.size();
    }
}

2.3 測(cè)試結(jié)果

通過(guò)測(cè)試

測(cè)試結(jié)果

3.總結(jié)

  • 利用二叉搜索樹(shù)中序遍歷結(jié)果是增序特性解答
  • 也可以直接使用列表的迭代器解答
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末欢峰,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌纽帖,老刑警劉巖宠漩,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異懊直,居然都是意外死亡扒吁,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)室囊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)雕崩,“玉大人,你說(shuō)我怎么就攤上這事融撞∨翁” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵尝偎,是天一觀的道長(zhǎng)饶火。 經(jīng)常有香客問(wèn)我,道長(zhǎng)致扯,這世上最難降的妖魔是什么肤寝? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮抖僵,結(jié)果婚禮上鲤看,老公的妹妹穿的比我還像新娘。我一直安慰自己耍群,他們只是感情好义桂,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著世吨,像睡著了一般澡刹。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上耘婚,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天罢浇,我揣著相機(jī)與錄音,去河邊找鬼沐祷。 笑死嚷闭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的赖临。 我是一名探鬼主播胞锰,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼兢榨!你這毒婦竟也來(lái)了嗅榕?” 一聲冷哼從身側(cè)響起顺饮,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎凌那,沒(méi)想到半個(gè)月后兼雄,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡帽蝶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年赦肋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片励稳。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡佃乘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出驹尼,到底是詐尸還是另有隱情趣避,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布扶欣,位于F島的核電站鹅巍,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏料祠。R本人自食惡果不足惜骆捧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望髓绽。 院中可真熱鬧敛苇,春花似錦、人聲如沸顺呕。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)株茶。三九已至来涨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間启盛,已是汗流浹背蹦掐。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留僵闯,地道東北人卧抗。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像鳖粟,于是被迫代替她去往敵國(guó)和親社裆。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

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