ディレクトリ
新しく、より包括的な「データ構造とアルゴリズム、」更新サイトは、より多くのpythonは、あなたが人工知能を教えるのを待っている、行く:< https://www.cnblogs.com/nickchen121/p/11407287.html
まず、問題の意味を理解します
2つのツリーのT1およびT2を考えます。T1は、子供について、いくつかの回で交換することができる場合はT2、我々は呼んで2本の木になり、「均質な。」今、2つのツリー与え、あなたは彼らが同型であるかどうかを判断します。
入力フォーマット:入力情報所与バイナリ2:
まず、行のツリーのツリー内のノードを指定されたN行が続きます
- i番目のノード番号に対応するI番目の行は、ノードは、その左の子ノード番号に格納された文字を与え、右の子ノード数
子ノードが空の場合、それぞれの位置で与えられました「 - 」
以下に示すように、そこにある様々な表現方法を、私たちは、次の2つのリストを表示します:
解決の第二に、アイデア
検索では、これを言うことですが、私は読んでのことは完全に法の道リンクリストを使用し、そう、少しの勉強方法は、完全に片方向リンクリストで記述していませんでした。
実際には、noneに設定され、このようなヘッドなどのメソッドのリスト全体を削除するには、よりエレガントな方法があるはず、次の改善のでしょうか?
# python语言实现
L1 = list(map(int, input().split()))
L2 = list(map(int, input().split()))
# 节点
class Node:
def __init__(self, coef, exp):
self.coef = coef
self.exp = exp
self.next = None
# 单链表
class List:
def __init__(self, node=None):
self.__head = node
# 为了访问私有类
def gethead(self):
return self.__head
def travel(self):
cur1 = self.__head
cur2 = self.__head
if cur1.next != None:
cur1 = cur1.next
else:
print(cur2.coef, cur2.exp, end="")
return
while cur1.next != None:
print(cur2.coef, cur2.exp, end=" ")
cur1 = cur1.next
cur2 = cur2.next
print(cur2.coef, cur2.exp, end=" ")
cur2 = cur2.next
print(cur2.coef, cur2.exp, end="")
# add item in the tail
def append(self, coef, exp):
node = Node(coef, exp)
if self.__head == None:
self.__head = node
else:
cur = self.__head
while cur.next != None:
cur = cur.next
cur.next = node
def addl(l1, l2):
p1 = l1.gethead()
p2 = l2.gethead()
l3 = List()
while (p1 is not None) & (p2 is not None):
if (p1.exp > p2.exp):
l3.append(p1.coef, p1.exp)
p1 = p1.next
elif (p1.exp < p2.exp):
l3.append(p2.coef, p2.exp)
p2 = p2.next
else:
if (p1.coef + p2.coef == 0):
p1 = p1.next
p2 = p2.next
else:
l3.append(p2.coef + p1.coef, p1.exp)
p2 = p2.next
p1 = p1.next
while p1 is not None:
l3.append(p1.coef, p1.exp)
p1 = p1.next
while p2 is not None:
l3.append(p2.coef, p2.exp)
p2 = p2.next
if l3.gethead() == None:
l3.append(0, 0)
return l3
def mull(l1, l2):
p1 = l1.gethead()
p2 = l2.gethead()
l3 = List()
l4 = List()
if (p1 is not None) & (p2 is not None):
while p1 is not None:
while p2 is not None:
l4.append(p1.coef * p2.coef, p1.exp + p2.exp)
p2 = p2.next
l3 = addl(l3, l4)
l4 = List()
p2 = l2.gethead()
p1 = p1.next
else:
l3.append(0, 0)
return l3
def L2l(L):
l = List()
L.pop(0)
for i in range(0, len(L), 2):
l.append(L[i], L[i + 1])
return l
l1 = L2l(L1)
l2 = L2l(L2)
l3 = List()
l3 = mull(l1, l2)
l3.travel()
print("")
l3 = List()
l3 = addl(l1, l2)
l3.travel()