[LeetCode_94] Binary Tree Inorder Traversal
###题目链接
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的更多相关文章
- LintCode Binary Tree Inorder Traversal
Binary Tree Inorder Traversal Given a binary tree, return the inorder traversal of its nodes' values ...
- 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日(4) Binary Tree Inorder Traversal
原题: Binary Tree Inorder Traversal 和 3月3日(2) Binary Tree Preorder Traversal 类似,只不过变成中序遍历,把前序遍历的代码拿出来, ...
- 49. leetcode 94. Binary Tree Inorder Traversal
94. Binary Tree Inorder Traversal 二叉树的中序遍历 递归方法: 非递归:要借助栈,可以利用C++的stack
- LeetCode: Binary Tree Inorder Traversal 解题报告
Binary Tree Inorder Traversal Given a binary tree, return the inorder traversal of its nodes' values ...
- [leetcode] 94. Binary Tree Inorder Traversal 二叉树的中序遍历
题目大意 https://leetcode.com/problems/binary-tree-inorder-traversal/description/ 94. Binary Tree Inorde ...
- [线索二叉树] [LeetCode] 不需要栈或者别的辅助空间,完成二叉树的中序遍历。题:Recover Binary Search Tree,Binary Tree Inorder Traversal
既上篇关于二叉搜索树的文章后,这篇文章介绍一种针对二叉树的新的中序遍历方式,它的特点是不需要递归或者使用栈,而是纯粹使用循环的方式,完成中序遍历. 线索二叉树介绍 首先我们引入“线索二叉树”的概念: ...
- 【LeetCode】94. Binary Tree Inorder Traversal (3 solutions)
Binary Tree Inorder Traversal Given a binary tree, return the inorder traversal of its nodes' values ...
- 二叉树前序、中序、后序非递归遍历 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 前序的非递归遍历:用堆来实现 如果把这个代码改成先向堆存储左节点再存储右节点,就变成了每一行从右向左打印 如果用队列替代堆,并且 ...
随机推荐
- Linux Centos6.5 SVN服务器搭建 以及客户端安装
转载:http://www.cnblogs.com/mymelon/p/5483215.html /******开始*********/ 系统环境:Centos 6.5 第一步:通过yum命令安装sv ...
- 排序NB三人组
排序NB三人组 快速排序,堆排序,归并排序 1.快速排序 方法其实很简单:分别从初始序列“6 1 2 7 9 3 4 5 10 8”两端开始“探测”.先从右往左找一个小于6的数,再从左往 ...
- css:自己实现一个带小图标的input输入框
有小图标的input输入框<input type="text" placeholder="输入手机号" style="background:ur ...
- BerOS File Suggestion(stl-map应用)
Polycarp is working on a new operating system called BerOS. He asks you to help with implementation ...
- Delphi的程序单元、结构、基础知识(转)
Object Passal的程序结构很特殊,与其它语言如C++,Object Windows等结构都不同.一个Delphi程序由多个称为单元的源代码模块组成.使用单元可以把一个大型程序分成多个逻辑相关 ...
- shell编程:基本语法
要掌握一门语言,就要先掌握它的语法.如同C语言一般,shell也有自己的语法. 变量 按照惯例,Shell变量通常由字母加下划线开头,由任意长度的字母.数字.下划线组成.有两种类型的Shell变量: ...
- Linux命令:ssh
ssh介绍 ssh用法 ssh帮助 SSH() BSD General Commands Manual SSH() NAME ssh — OpenSSH SSH client (remote logi ...
- 静态函数造成GC的原因
有时候用deep profiling查看GC时会发现:一个父函数有GC,展开子层级看到一个很奇怪的 CX::ctor,表示CX进行了构造,然后打开父函数代码却完全看不到有new CX的地方,这个时候可 ...
- 注解(Annotation)是什么?
- 使用__all__限制模块可被导入对象
经常我们会编写自定义模块,用于被别的脚本调用;有时候为了方便,会使用from module_name import *的方式导入,这样会把模块中全部对象导入进来; 使用__all__结合列表,可以控制 ...