当前位置: 首页 > news >正文

做淘宝客导购网站营销qq下载

做淘宝客导购网站,营销qq下载,WordPress底部中间添加备案号,主流b2b网站有哪些CV炼丹师勇闯力扣训练营 代码随想录算法训练营第13天 二叉树的递归遍历 二叉树的迭代遍历、统一迭代 二叉树的层序遍历 一、二叉树的递归遍历(深度优先搜索) 【递归步骤】 1.确定递归函数的参数和返回值:确定哪些参数是递归的过程中需要处理…

CV炼丹师勇闯力扣训练营

代码随想录算法训练营第13天
二叉树的递归遍历
二叉树的迭代遍历、统一迭代
二叉树的层序遍历


一、二叉树的递归遍历(深度优先搜索)

【递归步骤】
1.确定递归函数的参数和返回值:确定哪些参数是递归的过程中需要处理的,那么就在递归函数里加上这个参数, 并且还要明确每次递归的返回值是什么进而确定递归函数的返回类型。
2.确定终止条件: 写完了递归算法, 运行的时候,经常会遇到栈溢出的错误,就是没写终止条件或者终止条件写的不对,操作系统也是用一个栈的结构来保存每一层递归的信息,如果递归没有终止,操作系统的内存栈必然就会溢出。
3.确定单层递归的逻辑: 确定每一层递归需要处理的信息。在这里也就会重复调用自己来实现递归的过程

代码如下(Python):二叉树的前/中/后序遍历

from typing import List# Definition for a binary tree node.
class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = right# 前序遍历-递归-LC144_二叉树的前序遍历
class Solution:def preorderTraversal(self, root: TreeNode) -> List[int]:res = []def dfs(node):if node is None:returnres.append(node.val)dfs(node.left)dfs(node.right)dfs(root)return res# 中序遍历-递归-LC94_二叉树的中序遍历
class Solution2:def inorderTraversal(self, root: TreeNode) -> List[int]:res = []def dfs(node):if node is None:returndfs(node.left)res.append(node.val)dfs(node.right)dfs(root)return res# 后序遍历-递归-LC145_二叉树的后序遍历
class Solution3:def postorderTraversal(self, root: TreeNode) -> List[int]:res = []def dfs(node):if node is None:returndfs(node.left)dfs(node.right)res.append(node.val)dfs(root)return res"""  [1,2,4,5,3]1/ \2   3/ \4   5
"""
# 创建二叉树
root = TreeNode(1)
root.left = TreeNode(2)
root.right = TreeNode(3)
root.left.left = TreeNode(4)
root.left.right = TreeNode(5)# 实例化Solution并进行前序遍历
solution = Solution()
result = solution.preorderTraversal(root)# 打印前序遍历的结果
print(result)

二、二叉树的迭代遍历

三、二叉树的统一迭代

# Todo

四、二叉树的层序遍历(广度优先搜索)

层序遍历一个二叉树。就是从左到右一层一层的去遍历二叉树。这种遍历的方式和我们之前讲过的都不太一样。

需要借用一个辅助数据结构即队列来实现,队列先进先出,符合一层一层遍历的逻辑,而用栈先进后出适合模拟深度优先遍历也就是递归的逻辑。

而这种层序遍历方式就是图论中的广度优先遍历,只不过我们应用在二叉树上。

从左到右遍历层序遍历二叉树动画如图:

代码如下(Python)

"""
利用长度法
"""
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def levelOrder(self, root: Optional[TreeNode]) -> List[List[int]]:if not root:return []queue = collections.deque([root])result = []while queue:level = []for _ in range(len(queue)):cur = queue.popleft()level.append(cur.val)if cur.left:queue.append(cur.left)if cur.right:queue.append(cur.right)result.append(level)return result"""
递归法
"""
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def levelOrder(self, root: Optional[TreeNode]) -> List[List[int]]:if not root:return []levels = []def traverse(node, level):if not node:returnif len(levels) == level:levels.append([])levels[level].append(node.val)traverse(node.left, level + 1)traverse(node.right, level + 1)traverse(root, 0)return levels

http://www.tj-hxxt.cn/news/17860.html

相关文章:

  • 百润网站建设知乎seo优化
  • 找大学生做家教去哪个网站找好百度关键词优化技巧
  • 链接提交抖音seo搜索优化
  • 关于建设网站的需求百度信息流账户搭建
  • 设计的网站都有哪些内容何鹏seo
  • 上海专业网站建设维护东营网站推广公司
  • 六安门户网站建设哪家好电商引流推广方法
  • 做团购网站的公司培训机构seo
  • 重庆可做网站 APPseo资源
  • 班级网站网页设计百度账户登录
  • 中国空间站离地球多远seo推广公司哪家好
  • 宁波住房和城乡建设培训网站网络营销的传播手段
  • 企业文化学习心得郑州网站关键词优化外包
  • 企业网站备案代理公司百度商务合作电话
  • 西安网站推广公司电话关键词排名怎么查
  • 免费外贸b2c网站建设爱站网关键词长尾挖掘工具
  • 做网站技术人员短信营销平台
  • 私服充值网站怎么做的湖南网站建设平台
  • wordpress顶部加广告优化营商环境的意义
  • 天门建站外贸网站平台
  • 购买网站空间多少钱厦门人才网最新招聘信息网
  • 网站开发+.net+开源网络营销的应用
  • 做网站服务器多少钱软文广告的案例
  • 百度响应式网站怎么做seo指的是什么意思
  • 一个网站两个域名备案如何做网页制作
  • 做网站的开发工具买域名
  • 做网站后台的电子文库太原seo关键词排名
  • 公司简介宣传册设计样本图片电脑系统优化软件
  • 我想用c 来做网站如何网上销售自己的产品
  • 局网站建设申请网推怎么做