Leetcode 501. 二叉搜索樹(shù)中的眾數(shù)

題目描述

給定一個(gè)有相同值的二叉搜索樹(shù)(BST)典徊,找出 BST 中的所有眾數(shù)(出現(xiàn)頻率最高的元素)。

假定 BST 有如下定義:

  • 結(jié)點(diǎn)左子樹(shù)中所含結(jié)點(diǎn)的值小于等于當(dāng)前結(jié)點(diǎn)的值
  • 結(jié)點(diǎn)右子樹(shù)中所含結(jié)點(diǎn)的值大于等于當(dāng)前結(jié)點(diǎn)的值
  • 左子樹(shù)和右子樹(shù)都是二叉搜索樹(shù)

示例 1:

輸入:
給定 BST [1,null,2,2]

          1
           \
            2
           /  
          2  

返回[2].

解法1

利用二叉搜索樹(shù)特性

因?yàn)槎嫠阉鳂?shù)的中序遍歷為有序列表略水,所以相當(dāng)于在有序列表中,取眾數(shù)的值。所以只需要一次遍歷即可獲得每個(gè)元素的出現(xiàn)次數(shù)托启,即可獲得眾數(shù)。

class Solution(object):
    def findMode(self, root):
        """
        :type root: TreeNode
        :rtype: List[int]
        """
        self.maxTimes,self.curTimes=1,0
        self.ret,self.lastNode=[],None
        def addToRet(node):
            if node:
                addToRet(node.left)
                if self.lastNode and self.lastNode.val==node.val:
                    self.curTimes+=1
                else:
                    self.curTimes=1
                self.lastNode=node
                if self.curTimes==self.maxTimes:
                    self.ret.append(node.val)
                elif self.curTimes>self.maxTimes:
                    self.ret,self.maxTimes=[],self.curTimes
                    self.ret.append(node.val)
                addToRet(node.right)
        addToRet(root)
        return self.ret

解法2

作為普通二叉樹(shù)處理

遍歷二叉樹(shù)攘宙,將出現(xiàn)次數(shù)保存在map對(duì)象中屯耸,若次數(shù)等于最大出現(xiàn)次數(shù),則添加元素到ret結(jié)果集中蹭劈;若高于最大出現(xiàn)次數(shù)疗绣,則更新最大次數(shù)并清除結(jié)果集,重新添加當(dāng)前元素铺韧。

class Solution(object):
    def findMode(self, root):
        """
        :type root: TreeNode
        :rtype: List[int]
        """
        self.maxTimes=1
        self.map,self.ret=dict(),set()
        def addToRet(node):
            if node:
                addToRet(node.left)
                num=self.map.get(node.val,0)+1
                self.map[node.val]=num
                if num==self.maxTimes:
                    self.ret.add(node.val)
                elif num>self.maxTimes:
                    self.ret.clear()
                    self.ret.add(node.val)
                    self.maxTimes=num
                addToRet(node.right)
        addToRet(root)
        return list(self.ret)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末多矮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子哈打,更是在濱河造成了極大的恐慌塔逃,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件料仗,死亡現(xiàn)場(chǎng)離奇詭異湾盗,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)立轧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門格粪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)躏吊,“玉大人,你說(shuō)我怎么就攤上這事帐萎”确” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵吓肋,是天一觀的道長(zhǎng)凳怨。 經(jīng)常有香客問(wèn)我,道長(zhǎng)是鬼,這世上最難降的妖魔是什么肤舞? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮均蜜,結(jié)果婚禮上李剖,老公的妹妹穿的比我還像新娘。我一直安慰自己囤耳,他們只是感情好篙顺,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著充择,像睡著了一般德玫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上椎麦,一...
    開(kāi)封第一講書(shū)人閱讀 52,475評(píng)論 1 312
  • 那天宰僧,我揣著相機(jī)與錄音,去河邊找鬼观挎。 笑死琴儿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的嘁捷。 我是一名探鬼主播造成,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼雄嚣!你這毒婦竟也來(lái)了晒屎?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤缓升,失蹤者是張志新(化名)和其女友劉穎夷磕,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體仔沿,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡坐桩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了封锉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绵跷。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡膘螟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出碾局,到底是詐尸還是另有隱情荆残,我是刑警寧澤,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布净当,位于F島的核電站内斯,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏像啼。R本人自食惡果不足惜俘闯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望忽冻。 院中可真熱鬧真朗,春花似錦、人聲如沸僧诚。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)湖笨。三九已至旗扑,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間慈省,已是汗流浹背臀防。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留辫呻,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓琼锋,卻偏偏與公主長(zhǎng)得像放闺,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子缕坎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361