###题目链接
https://leetcode.com/problems/binary-tree-inorder-traversal/

###题意
二叉树的中序遍历

###代码(递归,C++)
其中函数返回类型不符合题目中要求,做相应更改即可A;

/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/ class Solution {
public:
vector<int> inorderVec;
void inorderTraversal(TreeNode* root) {
if(root==NULL){
return;
} if(root->left){
inorderTraversal(root->left);
}
inorderVec.push_back(root->val);
if(root->right){
inorderTraversal(root->right);
}
}
};

###相关
####二叉树的中序遍历非递归版
#####思路:

  • 当栈不为空或当前节点不为空:一路将左孩子压入栈直到当前节点为空,然后弹出栈顶元素并将它加入输出队列,将当前节点更新为其右孩子;再继续一路向左...

#####代码(Java)

class Solution {
public List<Integer> inorderTraversal(TreeNode root) {
List<Integer> list = new ArrayList<>();
Stack<TreeNode> stack = new Stack<>(); if (root == null) {
return list;
} TreeNode cur = root;
while (cur != null || !stack.isEmpty()) { //
while (cur != null) {
stack.push(cur);
cur = cur.left;
}
cur = stack.pop();
list.add(cur.val);
cur = cur.right;// } return list;
}
}

####二叉树的先序遍历非递归版
#####思路:

  • 使用栈。
  • 具体的,
    • 先把根节点压栈。
    • while(栈非空){栈顶元素弹出并打印,若其右孩子非空则入栈,若其左孩子非空则压栈}

#####代码(Java)

import java.util.ArrayList;
import java.util.List;
import java.util.Stack; class Solution {
public List<Integer> preorderTraversal(TreeNode root) {
List<Integer> l=new ArrayList<>();
Stack<TreeNode> s=new Stack<>();
if(root==null) {
return l;
}
s.add(root); while(!s.empty()) {
TreeNode node=s.pop();
l.add(node.val);
if(node.right!=null) {
s.push(node.right);
}
if(node.left!=null) {
s.push(node.left);
}
}
return l;
}
}

####二叉树的后序遍历非递归版
#####思路:

  • 变量dealedNode代表最近一个加入到输出队列的节点,stacktopNode记录当前栈顶节点。
  • 因为后序遍历要三次到达每个节点,在第三次才输出当前节点,所以根据栈顶元素的左孩子和右孩子是否刚处理完是否为空,分三种情况做下一步操作。
    • 具体的,每次循环更新栈顶元素变量。
    • 一 若上一个处理完的节点不是栈顶元素的左孩子也不是当前栈顶元素的右孩子,说明是第一次到达该节点,若栈顶元素左孩子不为空则压入左孩子
    • 二 若不符合上一条,且上一个处理完的节点不是栈顶元素的右孩子(等价于 上一个处理完的是栈顶元素的左孩子或栈顶元素的左孩子为null),则说明是第二次到达该节点,若栈顶元素右孩子不为空则压入右孩子。
    • 三 若不符合上两条,说明是第三次到达该节点,将该节点弹出,处理该节点(及将该节点加入输出队列),更新dealedNode变量。
    • 终止条件:栈为空

#####代码(Java)

import java.util.ArrayList;
import java.util.List;
import java.util.Stack; class Solution {
public List<Integer> postorderTraversal(TreeNode root) { List<Integer> l=new ArrayList<>();
Stack<TreeNode> s=new Stack<>();
if(root==null) {
return l;
} TreeNode dealedNode=root;
s.add(root);
TreeNode stackTopNode; while(!s.empty()) {
stackTopNode=s.peek();
if(dealedNode!=stackTopNode.left&&dealedNode!=stackTopNode.right&&stackTopNode.left!=null) {
s.add(stackTopNode.left);
}
else if(dealedNode!=stackTopNode.right&&stackTopNode.right!=null) {
s.add(stackTopNode.right);
}
else {
s.pop();
l.add(stackTopNode.val);
dealedNode=stackTopNode;
}
} return l;
}
}

####二叉树的层序遍历

class Solution {
public List<Integer> inorderTraversal(TreeNode root) {
List<Integer> l=new ArrayList<>();
LinkedList<TreeNode> q=new LinkedList<>();
if(root!=null) {
q.add(root);
while(!q.isEmpty()) {
TreeNode temproot=q.poll();
l.add(temproot.val);
if(temproot.left!=null) {
q.add(temproot.left);
}
if(temproot.right!=null) {
q.add(temproot.right);
}
}
}
return l;
}
}

[LeetCode_94] Binary Tree Inorder Traversal的更多相关文章

  1. LintCode Binary Tree Inorder Traversal

    Binary Tree Inorder Traversal Given a binary tree, return the inorder traversal of its nodes' values ...

  2. 37. Binary Tree Zigzag Level Order Traversal && Binary Tree Inorder Traversal

    Binary Tree Zigzag Level Order Traversal Given a binary tree, return the zigzag level order traversa ...

  3. 3月3日(4) Binary Tree Inorder Traversal

    原题: Binary Tree Inorder Traversal 和 3月3日(2) Binary Tree Preorder Traversal 类似,只不过变成中序遍历,把前序遍历的代码拿出来, ...

  4. 49. leetcode 94. Binary Tree Inorder Traversal

    94. Binary Tree Inorder Traversal    二叉树的中序遍历 递归方法: 非递归:要借助栈,可以利用C++的stack

  5. LeetCode: Binary Tree Inorder Traversal 解题报告

    Binary Tree Inorder Traversal Given a binary tree, return the inorder traversal of its nodes' values ...

  6. [leetcode] 94. Binary Tree Inorder Traversal 二叉树的中序遍历

    题目大意 https://leetcode.com/problems/binary-tree-inorder-traversal/description/ 94. Binary Tree Inorde ...

  7. [线索二叉树] [LeetCode] 不需要栈或者别的辅助空间,完成二叉树的中序遍历。题:Recover Binary Search Tree,Binary Tree Inorder Traversal

    既上篇关于二叉搜索树的文章后,这篇文章介绍一种针对二叉树的新的中序遍历方式,它的特点是不需要递归或者使用栈,而是纯粹使用循环的方式,完成中序遍历. 线索二叉树介绍 首先我们引入“线索二叉树”的概念: ...

  8. 【LeetCode】94. Binary Tree Inorder Traversal (3 solutions)

    Binary Tree Inorder Traversal Given a binary tree, return the inorder traversal of its nodes' values ...

  9. 二叉树前序、中序、后序非递归遍历 144. Binary Tree Preorder Traversal 、 94. Binary Tree Inorder Traversal 、145. Binary Tree Postorder Traversal 、173. Binary Search Tree Iterator

    144. Binary Tree Preorder Traversal 前序的非递归遍历:用堆来实现 如果把这个代码改成先向堆存储左节点再存储右节点,就变成了每一行从右向左打印 如果用队列替代堆,并且 ...

随机推荐

  1. layer.js 学习笔记

    了解到一个很好用的弹框插件,名字叫layer.js 前几天要在网页中改写alert函数,自己写了一个模态框,虽然效果出来了,但是点击关闭后,无法返回当前页面.请教大神时,说有一个叫layer.js的东 ...

  2. CAS单点登录原理解析

    转自: https://www.cnblogs.com/lihuidu/p/6495247.html 1.基于Cookie的单点登录的回顾        基于Cookie的单点登录核心原理: 将用户名 ...

  3. Delphi中QuotedStr介绍及使用

    delphi 函数给字符串两边加单引号并返回.声明:function QuotedStr(const S: string): string;用函数 QuotedStr把字符串S转换成为用引号括起来的字 ...

  4. Linux:客户端的实现

    写了一个简单的服务器软件,但是没有写客户端.现在我将客户端实现了,其实昨天已经说了客户端的实现步骤了. 步骤: socket() 初始化 connet()链接 从标准输入读数据fgets() 传数据到 ...

  5. upupw

    https://sourceforge.net/projects/upupw/files/ANK/

  6. ReactiveX 学习笔记(7)聚合操作符

    Mathematical and Aggregate Operators 本文的主题为处理 Observable 的聚合操作符. 这里的 Observable 实质上是可观察的数据流. RxJava操 ...

  7. Android中使用Lambda表达式开发

    参考文章:ImportNew 要在Android开发中使用lambda表达式,首先需要在 Module 的build.gradle中加入: compileOptions { targetCompati ...

  8. Unity3D脚本学习——运行时类

    AssetBundle 类,继承自Object.AssetBundles让你通过WWW类流式加载额外的资源并在运行时实例化它们.AssetBundles通过BuildPipeline.BuildAss ...

  9. 使用Flash Media Server(FMS)录制mp4格式的视频

    最近在做一个有关视频直播和点播的项目,客户的一个需求就是可以控制对直播流的录制,直播的实现采用的是Adobe的Flash Media Server,具体方式就是:视频采集端采集视频并编码->rt ...

  10. 吴裕雄 python oracle子查询的用法(3)

    import cx_Oracle conn = cx_Oracle.connect("scott/admin@localhost:1521/orcl")cursor = conn. ...