力扣——515. 在每个树行中找最大值

这篇博客介绍了如何使用层序遍历解决在每个树行中找到最大值的问题。通过创建队列进行层序遍历,同时维护当前层的最大值,当一层处理完毕后,更新最大值并进入下一层。代码中详细解释了每一步操作,包括处理节点、更新最大值以及判断何时进入下一层的逻辑。

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

 代码附解释

 d515. 在每个树行中找最大值

解决这道题的首要就是必须先理解层序遍历,在层序遍历的基础上加上判断什么时候是进入下一行的,解决了这两个问题就可以很快的实现代码,下面的代码已经做出了详细的解释。

题解:

public static List<Integer> largestValues(TreeNode root){
        List<Integer> result = new LinkedList<>();
        int now = 1;//当层剩余元素
        int next = 0;//记录下一行元素数量
        int max = root.val;//记录当前层的当前最大值
        if(root==null)return null;
        Queue<TreeNode> queue = new LinkedList<>();//用于层序遍历
        queue.add(root);
        while (!queue.isEmpty()) {
            root = queue.poll();//取出当前队列的队首
            int t = root.val;
            max = Math.max(max, t);//和之前的最大值比较
            if (root.left != null) {//判断左节点是否为null,若不为null,则让下一层的元素数量+1
                queue.add(root.left);
                next++;
            }

            if (root.right != null) {//判断右节点是否为null,若不为null,则让下一层的元素数量+1
                queue.add(root.right);
                next++;
            }
            now--;//处理了当前层的1个元素,所以要当前层未处理数量减1
            if (now == 0) {//如果当前层,元素数量为0,那么说明当前层已经处理完毕
                now = next;//进入下一层处理,将下一层的数量赋值到now
                next = 0;//下一层数量重置
                result.add(max);//将记录的这一层的最大值添加到队列
                if(!queue.isEmpty()) max = queue.peek().val;//如果队列不为空,就将当前最大值设置为下一层的第一个数
            }
        }
        return result;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值