怎么用Python递归式实现二叉树前序,中序,后序遍历
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,今天小编给大家分享一下怎么用Python递归式实现二叉树前序,中序,后序遍历的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章
千家信息网最后更新 2025年01月20日怎么用Python递归式实现二叉树前序,中序,后序遍历
今天小编给大家分享一下怎么用Python递归式实现二叉树前序,中序,后序遍历的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
记忆点:
前序:VLR
中序:LVR
后序:LRV
举例:
一颗二叉树如下图所示:
则它的前序、中序、后序遍历流程如下图所示:
1.前序遍历
class Solution: def preorderTraversal(self, root: TreeNode): def preorder(root: TreeNode): if not root: return res.append(root.val) preorder(root.left) preorder(root.right) res = [] preorder(root) return res
2.中序遍历
class Solution: def inorderTraversal(self, root: TreeNode): def inorder(root: TreeNode): if not root: return inorder(root.left) res.append(root.val) inorder(root.right) res = [] inorder(root) return res
3.后序遍历
class Solution: def postorderTraversal(self, root: TreeNode): def postorder(root: TreeNode): if not root: return postorder(root.left) res.append(root.val) postorder(root.right) res = [] postorder(root) return res
4.测试
class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right# 用列表递归创建二叉树def createTree(root,list_n,i): if i5.结果
6.补充
6.1N叉树前序遍历
"""# Definition for a Node.class Node: def __init__(self, val=None, children=None): self.val = val self.children = children"""class Solution: def postorder(self, root: 'Node') -> List[int]: def seq(root): if not root: return res.append(root.val) for child in root.children: seq(child) res = [] seq(root) return resN叉树后序遍历"""# Definition for a Node.class Node: def __init__(self, val=None, children=None): self.val = val self.children = children"""class Solution: def postorder(self, root: 'Node') -> List[int]: def seq(root): if not root: return for child in root.children: seq(child) res.append(root.val) res = [] seq(root) return res以上就是"怎么用Python递归式实现二叉树前序,中序,后序遍历"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
知识
篇文章
递归
内容
不同
很大
大部分
就是
更多
流程
知识点
结果
行业
记忆
资讯
资讯频道
逻辑
面的
频道
天都
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
在mysql中显示数据库
acl网络安全配置心得
软件开发的创始人是谁
十一旅游团软件开发
软件开发业务平台
施磊腾讯课堂集群服务器课程录播
哪个数据库不是中文数据库
网络安全微信对话手抄报
登录苹果id账号验证服务器出错
停服务器解封
小学生网络安全防护小妙招
自考数据库系统与应用课后题答案
大专生去学习软件开发
单台服务器搭建k8s
任务管理器应用服务器
网络安全险概念
ef 调用数据库方法
军营网络安全宣传周大讨论
我的世界封神斗罗服务器怎么换号
PQ查询M语言连接数据库
数据库安全的基本内容
图像识别数据库
去哪里接软件开发的单子
网络技术专业研究生院校排名
公安网络技术侦查专业
服务器滑轨 安装
魔兽世界进不了个别服务器
商周互联网科技
荣昌区媒体网络技术服务特点
怀柔区大型软件开发单价