ZOJ Problem Set - 1097 Code the Tree Python 實(shí)現(xiàn)

#encoding=utf8

 
import sys

 
class Node():

    '''結(jié)點(diǎn)'''

    
    def __init__(self, number):

        self.number = number

        # 相連的其它結(jié)點(diǎn)

        self.linked_nodes = []

    
    def is_leaf(self):

        '''判斷是否是葉子結(jié)點(diǎn)'''

        
        return len(self.linked_nodes) <= 1

    
                    
class Tree():

    '''樹'''

    
    def __init__(self, str_input):

        '''創(chuàng)建新的樹'''

        
        # 結(jié)點(diǎn)數(shù)

        self.n = 0

        # 存儲葉子結(jié)點(diǎn)江耀,下標(biāo)表示結(jié)點(diǎn)的數(shù)字

        # 這樣掃描一遍數(shù)組第一個非0元素就是

        # 要刪除的葉子結(jié)點(diǎn)

        self.leaves  = [0] * (50 + 1)

        # 棧用于輔助解析字符串

        stack = []

        number = 0

        for i in range(0, len(str_input)):

            c = str_input[i]

            if c == '(':

                stack.append(c)

            elif c == ' ':

                continue

            elif c == ')':

                node1 = stack.pop()

                # 彈出'('

                stack.pop()

                if len(stack) == 0:

                    if node1.is_leaf():

                        self.leaves[node1.number] = node1

                    break

                # node2是node1的相連結(jié)點(diǎn)

                node2 = stack[-1]

                node1.linked_nodes.append(node2)

                node2.linked_nodes.append(node1)

                
                # 如果是葉子結(jié)點(diǎn)

                if node1.is_leaf():

                    self.leaves[node1.number] = node1

            # 數(shù)字

            else:

                if number == 0:

                    # 判斷下一個字符是不是數(shù)字

                    if (str_input[i + 1].isdigit()):

                        number += 10 * int(c)

                        continue

                    else:

                        number = int(c)

                        new_node = Node(number)

                        stack.append(new_node)

                        number = 0

                        self.n += 1

                else:

                    number += int(c)

                    new_node = Node(number)

                    stack.append(new_node)

                    number = 0

                    self.n += 1

    
    def delete_min_leaf(self):

        '''刪除最小的葉子結(jié)點(diǎn),并返回該節(jié)點(diǎn)的數(shù)字'''

            
        for i in range(0, len(self.leaves)):

            node = self.leaves[i]

            if node != 0 and len(node.linked_nodes) == 1:

                node.linked_nodes[0].linked_nodes.remove(node)

                if (node.linked_nodes[0].is_leaf()):

                    self.leaves[node.linked_nodes[0].number] = node.linked_nodes[0]

                number = node.linked_nodes[0].number

                node.linked_nodes.pop()

                return str(number)

        
if __name__ == '__main__':

    
    for line in sys.stdin:

        tree = Tree(line.strip('\n'))

        for i in range(0, tree.n - 1):

            sys.stdout.write(tree.delete_min_leaf())

            if i != tree.n - 1 - 1:

                sys.stdout.write(' ')

        print ''
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末玛迄,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子焰雕,更是在濱河造成了極大的恐慌舵变,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,451評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件逸月,死亡現(xiàn)場離奇詭異栓撞,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)碗硬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評論 3 394
  • 文/潘曉璐 我一進(jìn)店門瓤湘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人恩尾,你說我怎么就攤上這事弛说。” “怎么了特笋?”我有些...
    開封第一講書人閱讀 164,782評論 0 354
  • 文/不壞的土叔 我叫張陵剃浇,是天一觀的道長。 經(jīng)常有香客問我猎物,道長虎囚,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,709評論 1 294
  • 正文 為了忘掉前任蔫磨,我火速辦了婚禮淘讥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘堤如。我一直安慰自己蒲列,他們只是感情好窒朋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蝗岖,像睡著了一般侥猩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上抵赢,一...
    開封第一講書人閱讀 51,578評論 1 305
  • 那天欺劳,我揣著相機(jī)與錄音,去河邊找鬼铅鲤。 笑死划提,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的邢享。 我是一名探鬼主播鹏往,決...
    沈念sama閱讀 40,320評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼骇塘!你這毒婦竟也來了伊履?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,241評論 0 276
  • 序言:老撾萬榮一對情侶失蹤绪爸,失蹤者是張志新(化名)和其女友劉穎湾碎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體奠货,經(jīng)...
    沈念sama閱讀 45,686評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡介褥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了递惋。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片柔滔。...
    茶點(diǎn)故事閱讀 39,992評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖萍虽,靈堂內(nèi)的尸體忽然破棺而出睛廊,到底是詐尸還是另有隱情,我是刑警寧澤杉编,帶...
    沈念sama閱讀 35,715評論 5 346
  • 正文 年R本政府宣布超全,位于F島的核電站,受9級特大地震影響邓馒,放射性物質(zhì)發(fā)生泄漏嘶朱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評論 3 330
  • 文/蒙蒙 一光酣、第九天 我趴在偏房一處隱蔽的房頂上張望疏遏。 院中可真熱鬧,春花似錦、人聲如沸财异。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽戳寸。三九已至呈驶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間庆揩,已是汗流浹背俐东。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留订晌,地道東北人。 一個月前我還...
    沈念sama閱讀 48,173評論 3 370
  • 正文 我出身青樓蚌吸,卻偏偏與公主長得像锈拨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子羹唠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評論 2 355

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