2025年--Lc313-662. 二叉树最大宽度--java版

1.题目

2.思路

q:存真实的树节点

list:存与 q 中节点一一对应的"位置编号 index"

(1)用 BFS 按层遍历二叉树。同时维护两份同步结构:

q 存当前层的真实节点;

list 存这些节点在完全二叉树中的位置编号 index。

(2)编号规则:

根节点 index = 1

左孩子 = 2 * index

右孩子 = 2 * index + 1

(3)每处理完一层:

q 和 list 中剩下的就是下一层的节点及其编号。

下一层宽度 = list.getLast() - list.getFirst() + 1

(4)res 记录所有层中最大的宽度。

例子1:

java 复制代码
       1
     /   \
    3     2
   / \     \
  5   3     9


补充:

list 这个链表的头部取出并删除第一个元素

3.代码实现

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public int widthOfBinaryTree(TreeNode root) {
        if(root==null)
        {
            return 0;
        }
        //记录当前节点
        Queue<TreeNode> q=new LinkedList<>();
        //记录当前节点的索引
        LinkedList<Integer> list=new LinkedList<>();
        q.offer(root);
        list.add(1);
        int res=1;
        while(!q.isEmpty())
        {  //记录当前层的元素个数
            int cnt=q.size();
            //q.poll() 取出来的都是从左到右的层序顺序。
            for(int i=0;i<cnt;i++)
            {
                //队列弹出第一个元素
                TreeNode cur=q.poll();
                //列表删除第一个元素并且赋值给curIndex
                Integer curIndex=list.removeFirst();
                //当前元素的左孩子不为空
                if(cur.left!=null)
                {//左孩子入队
                    q.offer(cur.left);
                    //记录左孩子的索引
                    list.add(curIndex*2);
                }
                if(cur.right!=null)
                {  //右孩子入队
                    q.offer(cur.right);
                    //记录右孩子索引
                    list.add(curIndex*2+1);
                    
                }
            }
            if(list.size()>0)
            {
            res=Math.max(res,list.getLast()-list.getFirst()+1);
            }
        }

        return res;
    }
}
相关推荐
程途知微21 分钟前
ConcurrentHashMap线程安全实现原理全解析
java·后端
lzhdim21 分钟前
SharpCompress:跨平台的 C# 压缩与解压库
开发语言·c#
嘿嘿嘿x326 分钟前
Linux记录过程
linux·开发语言
Mars酱27 分钟前
1分钟编写贪吃蛇 | JSnake贪吃蛇单机版
java·后端·开源
devpotato27 分钟前
人工智能(四)- Function Calling 核心原理与实战
java·人工智能
默 语34 分钟前
Records、Sealed Classes这些新特性:Java真的变简单了吗?
java·开发语言·python
止观止35 分钟前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
zjshuster43 分钟前
墨西哥中央银行网联清算系统接入总结
java·财务对账
小锋java123444 分钟前
SpringBoot 4 + Spring Security 7 + Vue3 前后端分离项目设计最佳实践
java·vue.js·spring boot
卷心菜狗1 小时前
Python进阶-深浅拷贝辨析
开发语言·python