本文总结了刷LeetCode过程中,有关树的遍历的相关代码实现,包括了二叉树.N叉树先序.中序.后序.BFS.DFS遍历的递归和迭代实现.这也是解决树的遍历问题的固定套路. 一.二叉树的先序.中序.后序遍历  1.递归模板  (1)先序 1 public void preorder(TreeNode root) { 2 if (root == null) { 3 return; 4 } 5 res.add(root.val); 6 preorder(root.left); 7 preorder(…
  在上一篇博客中,实现了Java中二叉树的三种遍历方式的递归实现,接下来,在此实现Java中非递归实现二叉树的前序.中序.后序遍历,在非递归实现中,借助了栈来帮助实现遍历.前序和中序比较类似,也简单一些,但是后序遍历需要两个栈来进行辅助,稍微复杂一些.   同样是那棵二叉树 前序遍历:4 2 1 3 6 5 7 8 10 中序遍历:1 2 3 4 5 6 7 8 10 后序遍历:1 3 2 5 10 8 7 6 4 import java.util.Stack; public class Tr…
  在上一篇博客中,实现了Java中二叉树的四种遍历方式的递归实现,接下来,在此实现Java中非递归实现二叉树的前序.中序.后序.层序遍历,在非递归实现中,借助了栈来帮助实现遍历.前序和中序比较类似,也简单一些,但是后序遍历需要两个栈来进行辅助,稍微复杂一些,层序遍历中借助了一个队列来进行实现.   同样是那棵二叉树 前序遍历:4 2 1 3 6 5 7 8 10 中序遍历:1 2 3 4 5 6 7 8 10 后序遍历:1 3 2 5 10 8 7 6 4 层序遍历:4 2 6 1 3 5 7…
二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的.对于二叉树,有前序.中序以及后序三种遍历方法.因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁.而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现.在三种遍历中,前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点. 节点分布如下: import java.util.LinkedList; import java.util.Queue; imp…
import java.util.HashMap; import java.util.LinkedList; import java.util.Map; import java.util.Queue; import java.util.Stack; /** * * @author kerryfish * JAVA实现二叉树的先序.中序.后序.层序遍历 * 递归和非递归版本 * */ class Node{ public int value; public Node left; public No…
上节中已经学会了如何构建一个二叉搜索数,这次来学习下树的打印-基于递归的DFS,那什么是DFS呢? 有个概念就行,而它又分为前序.中序.后序三种遍历方式,这个也是在面试中经常会被问到的,下面来具体学习下,用三种遍历方法来遍历上节中的二叉数: 前序遍历: 那对于上面的二叉数用前序遍历,遍历过程如下: 1.先遍历根节点[5] 2.再遍历左子树: 需要注意的是:遍历左右子树时仍然采用前序遍历方法.所以如下: a.先遍历根节点[3] b.再遍历左子树,由于只有一个结点则直接打印[1] c.再遍历右子树,…
Problem: 实现二叉树的先序.中序.后序遍历,包括递归方式和非递归方式 Solution: 切记递归规则: 先遍历根节点,然后是左孩子,右孩子, 根据不同的打印位置来确定中序.前序.后续遍历. Code: #pragma once #include <iostream> #include <vector> #include <queue> #include <stack> #include <string> #include <sst…
本文用递归算法实现二叉树的前序.中序和后序遍历,提供Java版的基本模板,在模板上稍作修改,即可解决LeetCode144. Binary Tree Preorder Traversal(二叉树前序遍历),94. Binary Tree Inorder Traversal(二叉树中序遍历),145. Binary Tree Postorder Traversal(二叉树后序遍历). 基本概念 二叉树的遍历是根据访问结点操作发生位置命名: 前序:访问根结点的操作发生在遍历其左右子树之前. 中序:访…
基础预热: 结点的度(Degree):结点的子树个数:树的度:树的所有结点中最大的度数:叶结点(Leaf):度为0的结点:父结点(Parent):有子树的结点是其子树的根节点的父结点:子结点/孩子结点(Child):若A结点是B结点的父结点,则称B结点是A结点的子结点:兄弟结点(Sibling):具有同一个父结点的各结点彼此是兄弟结点:路径和路径长度:从结点n1到nk的路径为一个结点序列n1,n2,…,nk.ni是ni+1的父结点.路径所包含边的个数为路径的长度:祖先结点(Ancestor):沿…
二叉树的创建是个麻烦事,我的思路是:首先将一个普通的二叉树转化为满二叉树,其中的空节点用一些标识数据来代替,如此一来,就可以用数组索引来描述数据在二叉树的什么位置了. 比如,数组[2,4,3,1,5,-1,-1] 就可以表示一个三层的二叉树,具体长这样: 对于四种遍历方法,前序.中序.后序.层次遍历方法,给出了递归和迭代两种方式 具体代码如下: #include <vector> #include <iostream> #include <algorithm> #inc…