Recover Binary Search Tree

Two elements of a binary search tree (BST) are swapped by mistake.

Recover the tree without changing its structure.Note:

A solution using O(n) space is pretty straight forward. Could you devise a constant space solution?


這個(gè)題我看到的想法是先把所有element in order走一遍悴了,然后存進(jìn)O(n) space的array. 然后排序。排序好以后重新建一個(gè)BST.

但是這種naive solution太暴力了翼雀,不知道該怎么優(yōu)化刹勃。

但是要做到constant space, 。。盼产。。不知道怎么搞勺馆。戏售。。難怪這題是Hard level...


我做的時(shí)候大概知道要keep reference of 兩個(gè)覺得不對勁的Node草穆。比如他比left 小 || 比right 大灌灾,這很明顯就不對。 但是我就算keep了兩個(gè)Node, 沒辦法交換呀悲柱,因?yàn)樾枰鋚arent才可以操控他們交換锋喜。還有就是我是不是還得save一個(gè)left or right告訴parent這是在左邊還是右邊。豌鸡。嘿般。


看完答案感覺傻逼了。涯冠。博个。原來根本不用交換node reference. 只要記錄node reference,交換value就好了功偿。

然后我開始寫代碼: 用pre-order的方式盆佣,只要left|| right 比root大/小, 就save it作為first/second

看上去好像很對械荷,但是問題非常明顯共耍。 當(dāng)碰到below case的時(shí)候,我只把0 keep as first.

然后到了leaf的時(shí)候吨瞎,因?yàn)闆]有l(wèi)eft, right 所以不會進(jìn)行判斷痹兜,然后就GG了。

所以看起來正確的姿勢還是得用In-order Traversal的方法颤诀。

發(fā)現(xiàn)In-order是第一步字旭,第二步最難的就是

if(first == null && root.val < prev.val)

? ? ? first = prev;

if (first!=null && root.val < prev.val)

? ? second = prev;

這個(gè)算法下,first這個(gè)東西一確立以后就不會再更改了崖叫。 但是second是會更改的遗淳,所以我們必須遍歷整個(gè)Tree。?


下面這個(gè)例子心傀,人眼看過去很明顯12比1大是ok的屈暗,1比10大不ok,10比1小不ok。



這個(gè)看過去养叛, 1比5大不ok种呐, 5 比1小不ok, 11比5小不ok弃甥,5比11大也不對爽室。

一開始First 定了是11,然后second是5. 看起來很有道理淆攻,這兩個(gè)確實(shí)好像被交換了肮之。但是繼續(xù)遍歷發(fā)現(xiàn),1那個(gè)node 也不應(yīng)該比5小啊卜录, 這個(gè)時(shí)候second就換成了1. 意思是

? ? ? ? ? ? ? ? ? 小

? ? ? ? ?中

把 大和小兩個(gè)換一下戈擒, 中不需要變,整個(gè)樹的2 swapped 就找到了艰毒。





這道題只assume 改了兩個(gè)node筐高,如果改了更多的話,就會出錯(cuò)丑瞧。

比如這個(gè):

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末柑土,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子绊汹,更是在濱河造成了極大的恐慌稽屏,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件西乖,死亡現(xiàn)場離奇詭異狐榔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)获雕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進(jìn)店門薄腻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人届案,你說我怎么就攤上這事庵楷。” “怎么了楣颠?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵尽纽,是天一觀的道長。 經(jīng)常有香客問我童漩,道長弄贿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任睁冬,我火速辦了婚禮挎春,結(jié)果婚禮上看疙,老公的妹妹穿的比我還像新娘豆拨。我一直安慰自己直奋,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布施禾。 她就那樣靜靜地躺著脚线,像睡著了一般。 火紅的嫁衣襯著肌膚如雪弥搞。 梳的紋絲不亂的頭發(fā)上邮绿,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機(jī)與錄音攀例,去河邊找鬼船逮。 笑死,一個(gè)胖子當(dāng)著我的面吹牛粤铭,可吹牛的內(nèi)容都是我干的挖胃。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼梆惯,長吁一口氣:“原來是場噩夢啊……” “哼酱鸭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起垛吗,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤凹髓,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后怯屉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蔚舀,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年锨络,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蝗敢。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,569評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡足删,死狀恐怖寿谴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情失受,我是刑警寧澤讶泰,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站拂到,受9級特大地震影響痪署,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜兄旬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一狼犯、第九天 我趴在偏房一處隱蔽的房頂上張望余寥。 院中可真熱鬧,春花似錦悯森、人聲如沸宋舷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽祝蝠。三九已至,卻和暖如春幻碱,著一層夾襖步出監(jiān)牢的瞬間绎狭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工褥傍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留儡嘶,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓恍风,卻偏偏與公主長得像蹦狂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子邻耕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評論 2 348

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