leetcode222

求完全二叉樹節(jié)點(diǎn)個(gè)數(shù)

原題地址https://leetcode.com/problems/count-complete-tree-nodes/description/
思路:先算出樹的高度level伴网,找尾節(jié)點(diǎn),看下結(jié)尾排列英上,看下h = 3最后一排的排列,0代表向左子樹搜索,1代表向右子樹搜索慎陵,可以用bit特位表示讥蟆,可以用二分查找法搜索拒垃,每一次從根節(jié)點(diǎn)向葉節(jié)點(diǎn)查找

#(0,0,0),(0,0,1)(0,1,0)(0,1,1)(1,0,0)(1,0,1)(1,1,0)(1,1,1)其實(shí)是
0窍侧,1县踢,2,3伟件,4硼啤,5,6斧账,7
# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
  
class Solution(object):
    # 先算數(shù)的深度
    def findlevel(self, root):
        if root:
             return 1+self.findlevel(root.left)
        else:
            return 0
    '''step就是用1代表(0,0,1),3'''  
    def findendNode(self, root, step, level):
        #print step,level
        temp = root
        for i in range(level):
            if ((step&(2**(level-1-i))) >> (level-1-i)) == 0:
                #print 'xxx'
                temp = temp.left
            else:
                temp = temp.right
        if temp:
            return True
        else:
            return False
                
    '''
    def findendNode(self, root, step, level):
        temp = root
        lr = list(bin(step))[2:]
        #print 'lr', lr, 'level', level
        lrlen = len(lr)
        # 左子樹
        for i in range(level-lrlen):
            temp = temp.left
        for i in range(lrlen):
            if lr[i] == '0':
                temp = temp.left
            else:
                temp = temp.right
        if temp:
            return True
        else:
            return False
    '''    
    def countNodes(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        if not root:
            return 0
        level=self.findlevel(root)-1
        if level == 0:
            return 1
        endend = 2**level
        s = endend - 1
        # 找出深度后呢谴返,找出結(jié)尾煞肾,看下結(jié)尾排列,看下h = 3最后一排的排列,0代表向左子樹搜索嗓袱,1代表向右子樹搜索籍救,可以用bit特         # 位表示,可以用二分查找法
        #(0,0,0),(0,0,1)(0,1,0)(0,1,1)(1,0,0)(1,0,1)(1,1,0)(1,1,1)其實(shí)就是0渠抹,1蝙昙,2,3逼肯,4耸黑,5桃煎,6篮幢,7
        start = 0
        end = endend-1
        while True:
            # 從中間找
            temp = (end+start)/2
            if not self.findendNode(root, temp, level):
                # 如果是false,設(shè)置為end
                end = temp
            else:
                # 如果是true为迈,設(shè)置為起點(diǎn)
                start = temp
            if end-start == 1:
                if end == endend-1:
                    if self.findendNode(root, end, level):
                        s += endend
                        return s
                    else:
                        s+= end
                        return s
                else:
                    s += end
                    return s
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末三椿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子葫辐,更是在濱河造成了極大的恐慌搜锰,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耿战,死亡現(xiàn)場(chǎng)離奇詭異蛋叼,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)剂陡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門狈涮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鸭栖,你說我怎么就攤上這事歌馍。” “怎么了晕鹊?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵松却,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我溅话,道長(zhǎng)晓锻,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任飞几,我火速辦了婚禮砚哆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘循狰。我一直安慰自己窟社,他們只是感情好券勺,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著灿里,像睡著了一般关炼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上匣吊,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天儒拂,我揣著相機(jī)與錄音,去河邊找鬼色鸳。 笑死社痛,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的命雀。 我是一名探鬼主播蒜哀,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼吏砂!你這毒婦竟也來了撵儿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤狐血,失蹤者是張志新(化名)和其女友劉穎淀歇,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體匈织,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡浪默,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缀匕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纳决。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖弦追,靈堂內(nèi)的尸體忽然破棺而出岳链,到底是詐尸還是另有隱情,我是刑警寧澤劲件,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布掸哑,位于F島的核電站,受9級(jí)特大地震影響零远,放射性物質(zhì)發(fā)生泄漏苗分。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一牵辣、第九天 我趴在偏房一處隱蔽的房頂上張望摔癣。 院中可真熱鬧,春花似錦、人聲如沸择浊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)琢岩。三九已至投剥,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間担孔,已是汗流浹背江锨。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留糕篇,地道東北人啄育。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像拌消,于是被迫代替她去往敵國(guó)和親挑豌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

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

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)拼坎。 張土汪:刷leetcod...
    土汪閱讀 12,747評(píng)論 0 33
  • LeetCode 刷題隨手記 - 第一部分 前 256 題(非會(huì)員)浮毯,僅算法題,的吐槽 https://leetc...
    蕾娜漢默閱讀 17,787評(píng)論 2 36
  • B樹的定義 一棵m階的B樹滿足下列條件: 樹中每個(gè)結(jié)點(diǎn)至多有m個(gè)孩子泰鸡。 除根結(jié)點(diǎn)和葉子結(jié)點(diǎn)外,其它每個(gè)結(jié)點(diǎn)至少有m...
    文檔隨手記閱讀 13,224評(píng)論 0 25
  • 原文出處:http://www.cnblogs.com/maybe2030/p/4715035.html引文出處:...
    明教de教主閱讀 9,181評(píng)論 0 7
  • 1 序 2016年6月25日夜壳鹤,帝都盛龄,天下著大雨,拖著行李箱和同學(xué)在校門口照了最后一張合照芳誓,搬離寢室打車去了提前租...
    RichardJieChen閱讀 5,105評(píng)論 0 12