数据结构与算法练习39

二叉树的层次遍历

在这里插入图片描述

解题思路:

由上往下层次遍历再反转顺序。

代码:

        public IList<IList<int>> LevelOrderBottom(TreeNode root)
        {
            IList<IList<int>> result = new List<IList<int>>();
            Queue<TreeNode> queue = new Queue<TreeNode>();//用来存储要遍历的那一层。
            Queue<TreeNode> temp = new Queue<TreeNode>();//用来存储添加的上一层。
            if (root != null)
                queue.Enqueue(root);
            while (queue.Count > 0)
            {
                IList<int> list = new List<int>();
                while (queue.Count > 0)
                {
                    TreeNode lgx = queue.Dequeue();
                    list.Add(lgx.val);
                    temp.Enqueue(lgx);
                }//每一次把queue中全部元素拿出来作为一层。
                result.Add(list);//存进结果中。
                while (temp.Count > 0)
                {
                    TreeNode lgx2 = temp.Dequeue();
                    if (lgx2.left != null)
                        queue.Enqueue(lgx2.left);
                    if (lgx2.right != null)
                        queue.Enqueue(lgx2.right);
                }//找这一层下面一层有哪些元素。
            }//知道queue中没有元素。
            return result.Reverse().ToList();//最后反转顺序。
        }

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值