首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

遍历总结

遍历 递归无返回值遍历 先序: public void preOrder(TreeNode root){ if (root == null){ return;...注意所有的遍历走过了路径都是相同的,只是输出(操作)的延迟问题,也可以在依靠遍历的回溯完成操作,递归操作是对当前节点的不同状态下不同情况的考虑,不需要考虑上下父子关系 判断是不是二茬排序 // 使用包装类可以传入数值为...将当前节点cur初始化为根节点 while cur不为null 如果cur没有左节点 cur添加到输出 进入右子树 cur = cur.right 否则 使用pre找打cur的前驱节点,使...任然属于大问题,转小问题的子类优化问题 实际上构建二叉只需要前序遍历或者中序遍历就可以 那么另一颗,只用于查找子树的大小 public TreeNode buildTree(int[] preorder...// 可以先写好计算高度的算法,然后后序遍历,在最后在计算左右子树的高度是否合法 // 相当于从先序的计算平衡二叉 public boolean isBalanced(TreeNode root

1.6K30

非递归遍历

先序非递归遍历二叉,中序非递归遍历二叉,后序非递归遍历二叉及双栈法。...先序非递归遍历二叉 先序非递归遍历比较简单,感觉与DFS类似,根据先序遍历的规则根左右,先将根节点压入栈,然后遍历左子树,再遍历左子树的左子树,一头走到NULL,把每次遍历的左子树的根节点依次入栈并把当前结点数据打印出来.../测试样例 //输入前三行 //9 //1 2 4 7 3 5 8 9 6 //先序 //4 7 2 1 8 5 9 3 6 // 中序 //7 4 2 8 9 5 6 3 1 // 后序 中序非递归遍历二叉...,此时当前结点为最左叶节点的根节点,然后遍历右节点,以此类推最后栈为空,遍历完毕。...n;++i) { scanf("%d",&b[i]); } Tree = Creat(a,b,n); travel_in(Tree); } return 0; } 后序非递归遍历二叉及双栈法

84710

输出二叉(二叉高度&二叉遍历

题目 在一个 m*n 的二维字符串数组中输出二叉,并遵守以下规则: 行数 m 应当等于给定二叉的高度。 列数 n 应当总是奇数。 根节点的值(以字符串格式给出)应当放在可放置的第一行正中间。...你应该将左子树输出在左下部分,右子树输出在右下部分。 左下和右下部分应当有相同的大小。即使一个子树为空而另一个非空,你不需要为空的子树输出任何东西,但仍需要为另一个子树留出足够的空间。...使用相同的规则输出子树。..."", "", "", "", ""] ["4", "", "", "", "", "", "", "", "", "", "", "", "", "", ""]] 注意: 二叉的高度在范围...解题 先求二叉高度height 根据高度知道列的宽度width = 2^height - 1 递归在区间中点填入节点的val的string格式 class Solution { public:

44410

初识JAVA:二叉之中序遍历

二叉是一种排序的基本的数据结构,而如果要想为多个对象进行排序,那么就必须可以区分出对象的大小,那么就必须依靠Comparable接口完成。...二叉的基本原理:取第一个元素作为根节点,之后每一个元素的排列要求:如果比根节点小的数据放在左子树,如果比根节点大的数据放在右子树,在输出的时候采用中序遍历(左-根-右)的方式完成。...}else{ this.right.addNode(newNode) ; // 继续向下判断 } } } public void printNode(){ // 输出的时候采用中序遍历...=null){ this.left.printNode() ; // 输出左子树 } System.out.print(this.data + "\t") ; if(this.right...root.addNode(newNode) ; // 确定是放在左子树还是放在右子树 } } public void print(){ this.root.printNode() ; // 通过根节点输出

18610

根据后序和中序遍历输出先序遍历

输出的先序遍历结果。...输入格式: 第一行给出正整数N(≤30),是中结点的个数。随后两行,每行给出N个整数,分别对应后序遍历和中序遍历结果,数字间以空格分隔。题目保证输入正确对应一棵二叉。...输出格式: 在一行中输出Preorder:以及该的先序遍历结果。数字间有1个空格,行末不得有多余空格。...输入样例: 7 2 3 1 5 7 6 4 1 2 3 4 5 6 7 输出样例: Preorder: 4 1 3 2 6 5 7 相关知识: 1.先序遍历的递归过程为:若二叉为空,遍历结束。...否则:①访问根结点;②先序遍历根结点的左子树;③先序遍历根结点的右子树。 简单来说先序遍历就是在深入时遇到结点就访问。 2.中序遍历的递归过程为:若二叉为空,遍历结束。

92110

前序遍历和中序遍历构造二叉

题意 根据前序遍历和中序遍历构造二叉. 注意事项: 你可以假设中不存在相同数值的节点 样例 给出中序遍历:[1,2,3]和前序遍历:[2,1,3]....返回如下的: 2 / \ 1 3 思路 根据前序遍历和中序遍历的规律可得: 前序遍历的第一个就是整个的根节点 这个根节点在中序遍历的左侧是其左子树,右侧是右子树。...将每一个节点都看作是一个单独的,根据此 规律1 和 规律2 依次递归获取其左右子树的前序与中序遍历,直到前序遍历或中序遍历的长度仅剩1,则说明该节点为叶子节点,从而构造整棵。...]; //右侧子节点的前序遍历 //从现有的中序遍历中拿到 左右子节点的中序遍历 for (int i = 0; i < inorder.length; i++) { if...treeRoot.right = buildTree(child_PreorderRight,child_InorderRight); return treeRoot; } } 原题地址 LintCode:前序遍历和中序遍历构造二叉

1.7K40
领券