0109有序鏈表轉(zhuǎn)換二叉搜索樹_Wise

題目描述

給定一個(gè)單鏈表秧秉,其中的元素按升序排序仰禀,將其轉(zhuǎn)換為高度平衡的二叉搜索樹甜攀。

本題中浑劳,一個(gè)高度平衡二叉樹是指一個(gè)二叉樹每個(gè)節(jié)點(diǎn) 的左右兩個(gè)子樹的高度差的絕對(duì)值不超過 1阱持。

示例:

給定的有序鏈表: [-10, -3, 0, 5, 9],

一個(gè)可能的答案是:[0, -3, 9, -10, null, 5], 它可以表示下面這個(gè)高度平衡二叉搜索樹:

      0
     / \
   -3   9
   /   /
 -10  5

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/convert-sorted-list-to-binary-search-tree
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán)魔熏,非商業(yè)轉(zhuǎn)載請(qǐng)注明出處衷咽。

解題思路

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def sortedListToBST(self, head: ListNode) -> TreeNode:
        # 首先轉(zhuǎn)成數(shù)組,就可以按照索引來快速獲取中間值
        arr = []
        result = []

        while head is not None:
            arr.append(head.val)
            head = head.next
        def sortedArryToBST(arr):
            if len(arr)==0:
                return None
            if len(arr) == 1:
                return TreeNode(arr[0])
            mid = (len(arr))//2 
            root = TreeNode(arr[mid])
            root.left = sortedArryToBST(arr[:mid])
            root.right = sortedArryToBST(arr[mid+1:])
            return root
        return sortedArryToBST(arr)
        
圖片.png

還可以使用快慢指針來獲得中間值


d072de5dd5b0ff86df59ff948b5f1b2.jpg

上述兩種方式都是尋找方法獲得中節(jié)點(diǎn) 用中間節(jié)點(diǎn)構(gòu)建root,導(dǎo)致我們每次構(gòu)建樹節(jié)點(diǎn)得時(shí)候都要尋找中間節(jié)點(diǎn)
能不能不尋找中間節(jié)點(diǎn)蒜绽,而是令建立節(jié)點(diǎn)的順序 匹配 鏈表元素順序镶骗?這樣每次建立節(jié)點(diǎn)時(shí),只需要獲取鏈表下一個(gè)元素即可躲雅。方法如下:

  • 使用遞歸模擬中序遍歷過程鼎姊,建立節(jié)點(diǎn)的順序即與鏈表元素順序一一對(duì)應(yīng),bottom-up建立樹相赁,最終返回根節(jié)點(diǎn)相寇。遞歸調(diào)用得最底層一個(gè)節(jié)點(diǎn)得左兒子是空,右兒子也是空钮科,只有父節(jié)點(diǎn)是鏈表得head.val唤衫。
  • 遞歸前需要統(tǒng)計(jì)鏈表長(zhǎng)度n,整體算法復(fù)雜度O(N)绵脯。

作者:jyd
鏈接:https://leetcode-cn.com/problems/two-sum/solution/convert-sorted-list-to-binary-search-tree-di-ding-/
來源:力扣(LeetCode)
著作權(quán)歸作者所有佳励。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán)休里,非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

class Solution:
    def __init__(self):
        self.head = None
    def sortedListToBST(self, head: ListNode) -> TreeNode:
        n, self.head = 0, head
        while head:
            head = head.next
            n += 1
        return self.to_bst(0, n - 1)
    def to_bst(self, left, right):
        if left > right: return
        m = (left + right) // 2
        left_child = self.to_bst(left, m - 1)
        father = TreeNode(self.head.val)
        self.head = self.head.next
        father.left = left_child
        father.right = self.to_bst(m + 1, right)
        return father

作者:jyd
鏈接:https://leetcode-cn.com/problems/two-sum/solution/convert-sorted-list-to-binary-search-tree-di-ding-/
來源:力扣(LeetCode)
著作權(quán)歸作者所有植兰。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán)份帐,非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末楣导,一起剝皮案震驚了整個(gè)濱河市废境,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌筒繁,老刑警劉巖噩凹,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異毡咏,居然都是意外死亡驮宴,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門呕缭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來堵泽,“玉大人,你說我怎么就攤上這事恢总∮蓿” “怎么了?”我有些...
    開封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵片仿,是天一觀的道長(zhǎng)纹安。 經(jīng)常有香客問我,道長(zhǎng)砂豌,這世上最難降的妖魔是什么厢岂? 我笑而不...
    開封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮阳距,結(jié)果婚禮上塔粒,老公的妹妹穿的比我還像新娘。我一直安慰自己筐摘,他們只是感情好窗怒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蓄拣,像睡著了一般。 火紅的嫁衣襯著肌膚如雪努隙。 梳的紋絲不亂的頭發(fā)上球恤,一...
    開封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音荸镊,去河邊找鬼咽斧。 笑死堪置,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的张惹。 我是一名探鬼主播舀锨,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼宛逗!你這毒婦竟也來了坎匿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤雷激,失蹤者是張志新(化名)和其女友劉穎替蔬,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體屎暇,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡承桥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了根悼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片凶异。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖挤巡,靈堂內(nèi)的尸體忽然破棺而出剩彬,到底是詐尸還是另有隱情,我是刑警寧澤玄柏,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布襟衰,位于F島的核電站,受9級(jí)特大地震影響粪摘,放射性物質(zhì)發(fā)生泄漏瀑晒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一徘意、第九天 我趴在偏房一處隱蔽的房頂上張望苔悦。 院中可真熱鬧,春花似錦椎咧、人聲如沸玖详。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蟋座。三九已至,卻和暖如春脚牍,著一層夾襖步出監(jiān)牢的瞬間向臀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來泰國打工诸狭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留券膀,地道東北人君纫。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像芹彬,于是被迫代替她去往敵國和親蓄髓。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

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