《剑指offer》从上往下打印二叉树
2024-08-26 15:10:48
本题来自《剑指offer》 从上往下打印二叉树
题目:
从上往下打印出二叉树的每个节点,同层节点从左至右打印。
思路:
一、广度优先搜索
队列的思想。
先将根节点加入,当取该节点时候,依次将左右子树加入,直到队列中的所有节点全部遍历便结束。
二、深度优先搜索
Python Code:
# -*- coding:utf-8 -*-
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
# 返回从上到下每个节点值列表,例:[1,2,3]
def PrintFromTopToBottom(self, root):
# write code here
res,result = [],[] #res保存没几个节点,result保存期值
if root: #假设是非空节点
res.append(root) #首先将根节点加入
i = 0
while True:
if res[i].left: #将左子树加入
res.append(res[i].left)
if res[i].right:
res.append(res[i].right) #将右子树加入
i += 1
if i == len(res): #将所有的节点全部遍历完毕,达到长度范围
break
for i in res:
if i:
result.append(i.val) #取res中的节点值放入到result中
return result
总结:
通过举个例子,通过对例子的操作最终会发现其中的通用的方法思路,对不同数据具有相同的操作,便放进循环之中。
最新文章
- iOS-证书
- MySQL/MariaDB/PerconaDB-提权条件竞争漏洞
- Spring XML配置文件示例(一)——<;Servlet name>;-servlet.xml
- C++学习笔记16:Linux系统编程基础1
- WPF的图片操作效果(一):RenderTransform
- 20145129 《Java程序设计》第5周学习总结
- java和javascript中this区别的浅探讨
- iOS开发中使用Bmob RESTful API
- 未能加载文件或程序集“WcfService”或它的某一个依赖项。试图加载格式不正确的程序。
- 揭开嵌入式c面试题背后的玄机
- Android Application的使用及其生命周期
- python 解析xml 文件: DOM 方式
- hdu1027
- Zeppelin interperter 模式设置总结
- SELECT 语句
- tomcat 启动窗口乱码
- window.name
- 基于C语言的磁引导园丁机器人源程序 --单片机应用
- npm 基本使用命令
- springboot整合dubbox与zookeeper