首页 > 其他分享 >LeetCode 44、144、145 使用非递归的方法遍历二叉树

LeetCode 44、144、145 使用非递归的方法遍历二叉树

时间:2022-12-18 21:26:21浏览次数:40  
标签:144 145 stack current 遍历 二叉树 null root 节点

前序遍历

如果要实现二叉的在非递归遍历需要借助这个数据结构。因为前序遍历先处理的是根节点再处理左子树和右子树,所以在循环之前需要将根棵树的根节点放入栈中,在循环中,将根元素的值出栈将其中的值加入至存储遍历结果的列表中,再判断左中节点是否存在,如果存在就将其入栈,直至栈空为止。
在子树节点入栈时,先将右子树的根节点入栈,再将左子树的根节点入栈。因为栈是后进先出,二叉树遍历先处理左子树再处理右子树,对应到栈这个数据结构中,先将右子树入栈再将左子树入栈,出栈时就将先将左子树的根节点出栈,先处理的也就是左子树。

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

后序遍历

后序遍历只需要在前序遍历基础将左右子树的根节点入栈顺序交换一下即可。
后序遍历二叉树处理的遍历是 左-->右-->中,
我们在交换了遍历顺序换的处理顺序是 中-->右-->左
两种遍历处理结点的顺序是互逆的,非递归处理完二叉树后,将结果集进行逆置操作返回。

public class Solution {
	public List<Integer> postorderTraversal(TreeNode root) {
		if (root == null) return null;
		Stack<Integer> stack = new Stack<Integer>();
		List<Integer> result = new ArrayList<Integer>()j;
		stack.psuh(root);
		while(!stack.isEmpty()) {
			TreeNode pop = stack.pop();
			result.add(pop.val);
			if (root.left != null) {
				stack.push(root.left);
			}
			if (root.right != null) {
				stack.push(root.right);
			}
		}
		return Collections.reverse(result);
	}
}

中序遍历

在处理中序遍历时,不像前序和中序遍历那样需要有单特的算法思路。
中序是先处理顺序是 左-->中-->右
从树根节点在开操作,先访问根节点,因为我们要先处理左结点需要,先将根节点在栈中保存下来,当处理到最左叶子节点时,将其中的元素放到结果集当中,出栈再弹出根节点,处理完根节点后,再处理右节点,以此类推即可。

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

循环条件 !stack.isEmpty()代表还有元素要处理,当处理完根元素时,stack.isEmpty()是空,但是还要右子树没有处理,我们还要加上current != null,并且以或关系运算。
在处理元素时,current != null代表还没有处理要根节点,需要将节点信息保存到栈中,因为先处理左子树所以current赋为左子树的值根节点的值,在current为空后,代表处理到了叶子节点,需要将值保存到结查集当中,再去处理右节点。

标签:144,145,stack,current,遍历,二叉树,null,root,节点
From: https://www.cnblogs.com/shushulelan/p/16990962.html

相关文章

  • 树转二叉树结点个数问题
    已知一棵有2011个结点的树,其叶结点个数为116,该树对应的二又树中无右孩子的结点的个数是()......
  • [ARC145] Non Arithmetic Progression Set
    ProblemStatementConstructaset$S$ofintegerssatisfyingalloftheconditionsbelow.Itcanbeprovedthatatleastonesuchset$S$existsundertheConst......
  • [ARC145B] AB Game
    ThegameisplayedbyAliceandBob.Initially,thereare$n$stones.Theplayersalternateturns,makingamovedescribedbelow,withAlicegoingfirst.Thep......
  • day36_0654.最大二叉树
    0654.最大二叉树该题部分没思路部分有思路但不会写代码因为自己写不出完整代码所以笔记就看卡哥解答过程吧详细通俗易懂我这里简单记录一下我都卡在什么地......
  • day37_0617.合并二叉树
    0617.合并二叉树classSolution{public:TreeNode*mergeTrees(TreeNode*root1,TreeNode*root2){intval1=0,val2=0;if(root1!=NUL......
  • LEETCODE 222. 完全二叉树的节点个数
    递归递归很简单,遍历整棵树即可,代码复杂度为O(n)点击查看代码funccountNodes(root*TreeNode)int{ifroot==nil{return0}return1+coun......
  • 二叉树的遍历
    1.二叉树的遍历二叉树主要有两种遍历方式:深度优先遍历:先往深走,遇到叶子节点再往回走。前序遍历(递归法,迭代法)中左右中序遍历(递归法,迭代法) 左中右后序遍历(递归法,迭代......
  • 洛谷-P1450 硬币购物
    P1450硬币购物容斥||\(dp\)+单调队列优化容易看出是个多重背包,然后拿单调队列优化一下后,计算量为\(O(4ns)\)这种做法的话就是单调队列优化板子题#include<bits/......
  • 二叉树前中后序递归遍历完整代码【超简单易懂】
    //二叉树的前中后序遍历【递归法】#include<iostream>usingnamespacestd;//结点结构体typedefstructBTnode{ chardata;//自己的数据 BTnode*lch......
  • 解决ORM错误:django.db.utils.IntegrityError: (1452, 'Cannot add or update a child
    #修改settings.pyDATABASES={'default':{'ENGINE':'django.db.backends.mysql','NAME':'test','HOST':'127.0.0.1','POR......