草庐IT

二叉树的前序、中序、后序遍历的迭代版本

二叉树的前序、中序、后序遍历的递归版本非常好理解,在这里就不在赘述了。这里主要讲迭代版本。事实上,计算机在进行递归调用时,会隐式的维护一个栈(叫做调用栈,CallStack),调用函数就把局部变量、入参、返回地址(合起来叫做栈帧,StackFrame)一同入栈,从函数返回就出栈。而迭代版本其实就是把这个过程显式的表现出来,手动的去维护这个栈。同时,迭代版本只需要把节点指针入栈出栈,占用的空间也会小一些。前序遍历因为前序遍历的递归版本是所谓的“尾递归”(即递归调用发生在函数体的尾部),将尾递归转换为迭代相对容易一些:voidpostOrder(TreeNode*root){//如果根节点为空,直

【2023.03.13】无脑秒解已知先/后序遍历与中序遍历,求先/后序遍历

CSP-J初赛中有许多此类题目,普通方法比较耗费时间以至于无法完成后面的题目,所以在这里介绍一下较快的一种方法。Bilibili:Link额,视频没有字幕,在学校的话没有耳机并不方便,这里手敲出来做法:注意,本文在介绍做法时以已知先序遍历与中序遍历为例;准备:算草纸和笔就够了(还有脑子;首先,将算草纸顺时针旋转90°,在算草纸(旋转后的状态)的第一行写下先/后序遍历的结果,如图:然后,将算草纸逆时针旋转90°,在算草纸(旋转后的状态)的最后一行写下中序遍历的结果,如图:额,下边为了方便书写,将省略“先序”和“中序”等字眼,并且将会把“ABCDE”替换为实例,请注意;把这张图当作平面直角坐标系,

【2023.03.13】无脑秒解已知先/后序遍历与中序遍历,求先/后序遍历

CSP-J初赛中有许多此类题目,普通方法比较耗费时间以至于无法完成后面的题目,所以在这里介绍一下较快的一种方法。Bilibili:Link额,视频没有字幕,在学校的话没有耳机并不方便,这里手敲出来做法:注意,本文在介绍做法时以已知先序遍历与中序遍历为例;准备:算草纸和笔就够了(还有脑子;首先,将算草纸顺时针旋转90°,在算草纸(旋转后的状态)的第一行写下先/后序遍历的结果,如图:然后,将算草纸逆时针旋转90°,在算草纸(旋转后的状态)的最后一行写下中序遍历的结果,如图:额,下边为了方便书写,将省略“先序”和“中序”等字眼,并且将会把“ABCDE”替换为实例,请注意;把这张图当作平面直角坐标系,

【LeetCode二叉树#16】二叉(搜索)树的最近公共祖先(递归后序遍历,巩固回溯机制)

二叉树的最近公共祖先力扣题目链接(opensnewwindow)给定一个二叉树,找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为:“对于有根树T的两个结点p、q,最近公共祖先表示为一个结点x,满足x是p、q的祖先且x的深度尽可能大(一个节点也可以是它自己的祖先)。”例如,给定如下二叉树:root=[3,5,1,6,2,0,8,null,null,7,4]示例1:输入:root=[3,5,1,6,2,0,8,null,null,7,4],p=5,q=1输出:3解释:节点5和节点1的最近公共祖先是节点3。示例2:输入:root=[3,5,1,6,2,0,8,null,null,

【LeetCode二叉树#16】二叉(搜索)树的最近公共祖先(递归后序遍历,巩固回溯机制)

二叉树的最近公共祖先力扣题目链接(opensnewwindow)给定一个二叉树,找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为:“对于有根树T的两个结点p、q,最近公共祖先表示为一个结点x,满足x是p、q的祖先且x的深度尽可能大(一个节点也可以是它自己的祖先)。”例如,给定如下二叉树:root=[3,5,1,6,2,0,8,null,null,7,4]示例1:输入:root=[3,5,1,6,2,0,8,null,null,7,4],p=5,q=1输出:3解释:节点5和节点1的最近公共祖先是节点3。示例2:输入:root=[3,5,1,6,2,0,8,null,null,