圆月山庄资源网 Design By www.vgjia.com
一、题意理解
给定两棵树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()
以上就是本次介绍的全部内容知识点,相关内容可以参阅下方知识点,感谢大家对的支持。
标签:
python,树的同构
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月05日
2024年11月05日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]