#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 ''
ZOJ Problem Set - 1097 Code the Tree Python 實(shí)現(xiàn)
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門瓤湘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人恩尾,你說我怎么就攤上這事弛说。” “怎么了特笋?”我有些...
- 文/不壞的土叔 我叫張陵剃浇,是天一觀的道長。 經(jīng)常有香客問我猎物,道長虎囚,這世上最難降的妖魔是什么? 我笑而不...
- 正文 為了忘掉前任蔫磨,我火速辦了婚禮淘讥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘堤如。我一直安慰自己蒲列,他們只是感情好窒朋,可當(dāng)我...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蝗岖,像睡著了一般侥猩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上抵赢,一...
- 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼骇塘!你這毒婦竟也來了伊履?” 一聲冷哼從身側(cè)響起,我...
- 序言:老撾萬榮一對情侶失蹤绪爸,失蹤者是張志新(化名)和其女友劉穎湾碎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體奠货,經(jīng)...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡介褥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了递惋。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片柔滔。...
- 正文 年R本政府宣布超全,位于F島的核電站,受9級特大地震影響邓馒,放射性物質(zhì)發(fā)生泄漏嘶朱。R本人自食惡果不足惜,卻給世界環(huán)境...
- 文/蒙蒙 一光酣、第九天 我趴在偏房一處隱蔽的房頂上張望疏遏。 院中可真熱鬧,春花似錦、人聲如沸财异。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽戳寸。三九已至呈驶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間庆揩,已是汗流浹背俐东。 一陣腳步聲響...
- 正文 我出身青樓蚌吸,卻偏偏與公主長得像锈拨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子羹唠,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- Day 12 神句文檔 The team contends that these bear more than a...
- Given a binary treestruct TreeLinkNode {TreeLinkNode *lef...
- 動態(tài)規(guī)劃題佩微。思路就是暴力搜索缝彬,以每層為單位搜索,并且狀態(tài)數(shù)目不多哺眯,把每一行的方格壓縮為二進(jìn)制編碼谷浅。 Python代碼:
- xxx is automatically signed for development, but a confli...
- AFHTTPSessionManager *manager =[AFHTTPSessionManager mana...