java递归 花一晚上也无法理解二叉树的非递归遍历,我该继续学下去吗?
浏览量:1485
时间:2021-03-17 18:08:44
作者:admin
花一晚上也无法理解二叉树的非递归遍历,我该继续学下去吗?
通常,花更多的时间是必要的。首先需要了解堆栈的操作和意义,还需要了解遍历二叉树的思想。有人用节点着色来编写非递归算法,即黑、灰、白三种颜色代表节点的状态,未被访问的节点为白色,未被访问的节点为灰色,被访问的节点为黑色。对于中间顺序遍历,除非访问了左子树,否则需要访问当前节点,所以依次沿左子树搜索,找到叶子后访问,然后退出右堆栈上的元素,并在右子树上执行相应的操作,直到堆栈为空。
es6递归查树结构?
代码示例:
树结构查找所有叶节点
/*参数
*数组树结构查找所有叶节点
*/
函数parsetreejson(数组){
for(let index=0 index<数组长度Index){
const element=array[Index
//1。法官元素.子元素是对象
如果(元素.子元素&&;类型(元素.子元素)==“object”){
parseTreeJson(元素.子元素)
}Else{
//判断是否是子节点
if(元素.isLastLevel=== 1) {
控制台.log( 元素.des“身份证号码:元素id)
//获取比赛
节点.推送(元素)
//获取节点ID点按( 元素id)
}
}
}
}
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。