首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

非递归遍历树

先序非递归遍历二叉树,中序非递归遍历二叉树,后序非递归遍历二叉树及双栈法。...先序非递归遍历二叉树 先序非递归遍历比较简单,感觉与DFS类似,根据先序遍历的规则根左右,先将根节点压入栈,然后遍历左子树,再遍历左子树的左子树,一头走到NULL,把每次遍历的左子树的根节点依次入栈并把当前结点数据打印出来...= Creat(a+1,b,i); T->rchild = Creat(a+i+1,b+i+1,n-i-1); return T; } } return NULL; } //先序非递归遍历...= Creat(a+1,b,i); T->rchild = Creat(a+i+1,b+i+1,n-i-1); return T; } } return NULL; } //中序遍历非递归...单栈法 后序非递归遍历和先序中序非递归开始类似,先将左子树的左孩子的的左孩子的….每个节点压入栈。

87110

树的非递归遍历

树使用递归遍历非常方便,如果将代码拉伸开来,我们能否是否非递归代码来实现呢?当然是可以的,我们只要把递归的循环步骤修改为while就可以了。...并放弃其左子树; 如果结点没有左子树,访问该结点; 步骤2: 如果结点有右子树,重复步骤1; 如果结点没有右子树(结点访问完毕),根据栈顶指示回退,访问栈顶元素,并访问右子树,重复步骤1 如果栈为空,表示遍历结束...TirTNode* findLeft(TirTNode* tree, std::stack& st) { if (nullptr == tree) return nullptr; // 持续遍历...= pLeft->rightChild) { // 如果有,则遍历这个树下最深的左子树 pLeft = findLeft(pLeft->rightChild, st); } else //如果节点没有右子树...st.empty()) { // 访问栈顶元素 pLeft = st.top(); // 弹出 st.pop(); } else { // 遍历完成 return; } } } } 调用时,只需给 myTreeOrder

19520
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    树的非递归遍历

    前序遍历 解法1: 图画的有点难看 说一下大概思路 1.借助一个栈 把root扔进栈中 2.此时栈中有一个root元素 一直判断栈为空即可 3.其次栈内先放右树元素 再放左边元素 因为栈是先进后出原理...cur走完左子树 并且加入到list中 2.左子树走完 走右子树 弹出顶部元素 并且访问它的右子树 3.外层循环 当走完右树 可能cur判空 但是栈不为空 所有得加上判空 不然栈内没出完 中序遍历...它是左子树遍历完 去右子树遍历时候 打印即可 后序遍历 在前序遍历解法一的基础上只需略微修改即可便可得到后序遍历 前序遍历是 根左右 代码写成 根 右 左 实现了前序遍历 再实现一下根右左...后序遍历是 左右根 根右左 翻转 便可得到左右根 public List postorderTraversal(TreeNode root) {...如果右子树已经被访问(即top.right == prev),这表示已经完成了对右子树的遍历,也可以访问top ​​ 可以尝试画图理解 不懂可以私信我 层序遍历 public List<List

    9610

    二叉树的非递归遍历(递归和非递归)

    对于二叉树,有前序、中序以及后序三种遍历方法。因为树的定义本身就是 递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁。而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现。...在三种遍历中, 前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点。 一.前序遍历    前序遍历按照“根结点-左孩子-右孩子”的顺序进行访问。  ...//非递归前序遍历  void pre_order(BTree *root)        {       stack s;       BTree *p = root;   while...//非递归中序遍历  void in_order(BTree *root)        {       stack s;       BTree *p = root;   while...       后序遍历的非递归实现是三种遍历方式中最难的一种。

    1.5K100

    二叉树的遍历——递归和非递归

    对于二叉树,有前序、中序以及后序三种遍历方法。因为树的定义本身就是 递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁。而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现。...在三种遍历中, 前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点。 一.前序遍历    前序遍历按照“根结点-左孩子-右孩子”的顺序进行访问。  ...->lchild);     //前序遍历左子树         pre_order(root->rchild);    //前序遍历右子树      }     }     2.非递归实现...//非递归前序遍历 void pre_order(BTree *root) { stack s; BTree...        后序遍历的非递归实现是三种遍历方式中最难的一种。

    1.2K80

    聊聊二叉树的遍历(递归和非递归)

    满二叉搜索树 二叉树的遍历 ? 二叉树的遍历有三种方式:先序遍历,中序遍历,后序遍历。思路很简单,这里面说的顺序的序是指每个子树根节点的遍历(打印)顺序。...递归版本(先、中、后序) 递归版的遍历算法很简单了,我们只需要改变打印次序就好了,也没有什么可讲的!...// 递归版// 先序遍历void printPreorder1(TreeNode* head){ if (head == nullptr){ return; }...printPostorder1(head->left); printPostorder1(head->right); cout value << " ";} 非递归版本...(先、中、后序) 首先我们要清楚,任何算法的递归版本都可以改成非递归版本,因为函数递归调用其实质就是压栈的过程,那么我们完全可以使用堆栈来模拟这个过程!

    95030

    二叉树的非递归遍历

    对于二叉树,有前序、中序以及后序三种遍历方法。因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁。而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现。...在三种遍历中,前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点。 一.前序遍历    前序遍历按照“根结点-左孩子-右孩子”的顺序进行访问。   ...void preOrder2(BinTree *root) //非递归前序遍历 { stack s; BinTree *p=root; while(p!...void inOrder2(BinTree *root) //非递归中序遍历 { stack s; BinTree *p=root; while(p!...       后序遍历的非递归实现是三种遍历方式中最难的一种。

    76010

    二叉树后序遍历的非递归实现_二叉树的后序遍历非递归详细

    一、递归实现前序,序,后序遍历; 对于二叉树,前面已经采用递归的方式实现的其前序,中序,后序遍历,具体请参见: http://blog.csdn.net/dai_wen/article/details/...78955411 那么,如何采用非递归的方式遍历树呢?...下面,以实现中序遍历二叉树为主题展开: 二、非递归实现 中序遍历: 1,结构: 首先,对于中序遍历,我们知道,原则是先走到的结点后访问,后走到的结点先访问,这显然是栈的结构; 2,访问结点的具体步骤:...; 注意:入栈结点本身没有被访问过,同时,其右子树也没有被访问过; 3,流程图: 那么,根据文字,画出如下流程图: //下面,举个例子: 如下所示的五个结点的二叉树,其非递归中序遍历如下图所示...rchild = &b3; b2.lchild = &b4; b3.lchild = &b5; InOrder2(&b1); return 0; } (3)程序实现结果: (4)总结,非递归实现中序遍历

    47330

    二叉树的前、中、后遍历(递归非递归)

    二叉树的遍历 二叉树的前序遍历 访问根结点,先序遍历左子树,先序遍历右子树 遍历基本步骤为先根结点,然后左子树,然后右子树, 需要注意的是这个遍历需要类似于递归,在访问完A以后,需要去访问B,这时,需要把...B当做一个根结点,下一次应该去访问D而不是C,只到访问到G即叶子节点以后才会递归的往回访问,所有节点都可以看作为父节点,叶子节点可以看做两个孩子为空的父节点 二叉树的中序遍历 中序遍历左子树,访问根结点...后选遍历为先遍历左子树,若其节点有左子树,则会往下递归找到最后一个左子树开始,然后遍历右子树,如果右子树有子节点,将会按照前面的方法进行遍历。...(递归遍历) 存储结构 class Node { public Node left; public Node right; public String data; public...System.out.print(node.data); inOrder(node.right); } } 二叉树的非递归实现

    96500

    非递归方式实现二叉树后序遍历_二叉树递归遍历

    二叉树前序遍历 对于一种数据结构而言,我们最常见的就是遍历,那么关于二叉树我们该如何去遍历呢? 请看大屏幕 。。。。...首先让我们来看看如何递归的去前序遍历二叉树 注:在这里我特别强调一点,在我们二叉树中,如果采用递归的方式,大部分都采用的根左右的方式,即采用子问题的方式,即先处理跟节点,再处理左子树,再处理右子树的这样一种思想...前序递归遍历 /** * Definition for a binary tree node...那么接下来我们再看看非递归的方式 前序非递归遍历 /** * Definition for a binary tree node....s.top(); s.pop(); cur=top->right; } return v; } }; 这就是前序遍历的非递归方式

    41310
    领券