###题目链接
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. WPF 透明窗体

    窗体属性中设置:Background="Transparent" AllowsTransparency="True" WindowStyle="Non ...

  2. 各种Queue分析

    Queue主要方法的区别:   抛出异常 返回特殊值 插入 add(e)插入成功则返回true,没有可用空间则IllegalStateException offer(e) 移除 remove(e)获取 ...

  3. ajax用户名存在检测

    一.ajax请求的四个步骤: 1.创建ajax对象 var xmlhttp=new XMLHttpRequest();//IE5,IE6以外的浏览器 var xmlhttp=new ActiveXOb ...

  4. git release功能

    命令行: git tag -a v3. -m "这是4.0版本" git push origin v3. //git tag -a 标签名称 -m "说明" / ...

  5. C++“隐藏实现,开放接口”的实现方案

    为什么要有接口? 接口就是一个程序与其它程序交流的窗口.就比如有一个电视机,我并不需要知道它是怎样工作的,我只要知道按电源键就可以开启电视,按节目加(+)减(-)可以切换电视频道就可以了. Java程 ...

  6. C++17尝鲜:编译期 if 语句

    Constexpr If(编译期 if 语句) 以 if constexpr 打头的 if 语句被称为 Constexpr If. Constexpr If 是C++17所引入的新的语法特性.它为C+ ...

  7. WebStorm新创建项目介绍

    WebStorm创建一个项目 这里支持有很多的类型项目: Empty Project         ----一个空的项目 Html5 Boilerplate     ----HTML5开发框架 We ...

  8. 2018软件工程W班助教小结博客

    一.总体回顾 我是汪老师实验室的研二的一名研究生,在研一的课程中就上过老师带的高级软件工程(采取的模式是一样的,亲身经历了一学期所以对整体流程比较清楚).实验室的学生当老师实践课的助教是这几年流传下来 ...

  9. [C语言]逆序的三位数

    ---------------------------------------------------------------------------------------- //  main.c ...

  10. Logo tools

    http://www.cilogo.com/LOGO/