python树的同构学习笔记
作者:小白专场 时间:2022-10-23 02:06:29
一、题意理解
给定两棵树T1和T2。如果T1可以通过若干次左右孩子互换就变成T2,则我们称两棵树是“同构的”。现给定两棵树,请你判断它们是否是同构的。
输入格式:输入给出2棵二叉树的信息:
先在一行中给出该树的结点树,随后N行
第i行对应编号第i个结点,给出该结点中存储的字母、其左孩子结点的编号、右孩子结点的编号
如果孩子结点为空,则在相应位置给出“-”
如下图所示,有多种表示的方式,我们列出以下两种:
二、求解思路
搜到一篇也是讲这个的,但是那篇并没有完全用到单向链表的方法,所以研究了一下,写了一个是完全用单向链表的方法:
其实应该有更优雅的删除整个单向列表的方法,比如头设为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()
来源:https://www.cnblogs.com/nickchen121/p/11518875.html
标签:python,树的同构
0
投稿
猜你喜欢
Python 多个图同时在不同窗口显示的实现方法
2022-07-02 01:20:35
python编程学习使用管道Pipe编写优化代码
2023-08-20 04:08:45
python批量修改交换机密码的示例
2023-06-29 07:52:42
keras K.function获取某层的输出操作
2023-03-11 15:10:21
Python使用SocketServer模块编写基本服务器程序的教程
2023-09-19 12:44:12
Python装饰器限制函数运行时间超时则退出执行
2022-09-07 18:12:54
ORACLE常见错误代码的分析与解决(一)
2010-08-02 13:20:00
Phar反序列化超详细介绍
2023-06-05 07:06:02
python中安装Scrapy模块依赖包汇总
2023-11-08 07:06:25
python中的Pytorch建模流程汇总
2022-04-26 19:02:14
MySQL优化方案参考
2024-01-24 03:28:03
五个小窍门帮你写出更好的CSS代码
2009-06-09 12:42:00
SQL Server主键约束(PRIMARY KEY)
2024-01-24 04:46:56
python视频转化字节问题的完整实现
2023-05-21 16:55:28
asp 在线备份与恢复sql server数据库的代码
2010-07-31 18:52:00
BeautifulSoup中find和find_all的使用详解
2023-11-08 21:00:22
MySQL中基本的多表连接查询教程
2024-01-13 10:44:15
Django视图函数的具体使用
2023-07-25 11:02:54
动态语言、动态类型语言、静态类型语言、强类型语言、弱类型语言介绍
2023-04-24 19:48:44
一个CSS图片切换效果代码
2008-02-12 12:17:00