js前序遍历二叉树(迭代)

本文介绍了如何通过JavaScript实现二叉树的前序遍历,利用栈的数据结构,遵循左-右的顺序,从根节点开始,依次访问并存储节点值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

https://blog.youkuaiyun.com/weixin_45334589/article/details/136220521?spm=1001.2014.3001.5502
通过上文构建二叉树

	//前序遍历 中->左->右
	var preorderTraversal = function(root){
        const stack = [root]; //头节点进栈
        var res = []; //保存结果
        while(stack.length>0){
            var cur = stack.pop(); //保存栈顶元素
            res.push(cur.val)      //将栈顶元素保存结果集
            //因为栈的性质先进后出,所以先右到左入栈,出栈时就是左到右
            if(cur.right!=null){   //如果栈顶节点存在左右节点,入栈
                stack.push(cur.right)
            }
            if(cur.left!=null){
                stack.push(cur.left)
            }
        }
        return res
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值