本题来自《剑指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

总结:

  通过举个例子,通过对例子的操作最终会发现其中的通用的方法思路,对不同数据具有相同的操作,便放进循环之中。

最新文章

  1. iOS-证书
  2. MySQL/MariaDB/PerconaDB-提权条件竞争漏洞
  3. Spring XML配置文件示例(一)——<Servlet name>-servlet.xml
  4. C++学习笔记16:Linux系统编程基础1
  5. WPF的图片操作效果(一):RenderTransform
  6. 20145129 《Java程序设计》第5周学习总结
  7. java和javascript中this区别的浅探讨
  8. iOS开发中使用Bmob RESTful API
  9. 未能加载文件或程序集“WcfService”或它的某一个依赖项。试图加载格式不正确的程序。
  10. 揭开嵌入式c面试题背后的玄机
  11. Android Application的使用及其生命周期
  12. python 解析xml 文件: DOM 方式
  13. hdu1027
  14. Zeppelin interperter 模式设置总结
  15. SELECT 语句
  16. tomcat 启动窗口乱码
  17. window.name
  18. 基于C语言的磁引导园丁机器人源程序 --单片机应用
  19. npm 基本使用命令
  20. springboot整合dubbox与zookeeper

热门文章

  1. python日志1
  2. linux一些比较重要的环境变量。配置文件
  3. mysql 半同步复制~ 整体概述与改进
  4. JAVA知识笔记
  5. Spring boot+Thymeleaf+easyui集成:js创建组件页面报错
  6. 词向量之Word2vector原理浅析
  7. P3830 [SHOI2012]随机树 题解
  8. day2 --> pyc 文件
  9. 制作ecc证书(linux命令行)
  10. css3时钟