LeetCode 662 二叉树最大宽度

原题链接

标签 :二叉树 BFS

解题思路:BFS广度优先 + 队列   

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:int widthOfBinaryTree(TreeNode* root) {if (!root) return 0;queue<pair<TreeNode*, unsigned long long>> q;int ans = 1;q.push({root, 1});while (!q.empty()) {int sz = q.size();ans = max(int(q.back().second - q.front().second + 1), ans);for (int i=0; i < sz; i++) {TreeNode *node = q.front().first;unsigned long long pos = q.front().second;q.pop();if (node->left) q.push({node->left, 2 * pos});if (node->right) q.push({node->right, 2 * pos + 1});}}return ans;}
};

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/336491.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mockito 静态_在Java 8中使用不带静态导入的Mockito

mockito 静态如何通过在基于Java 8的项目中删除静态导入来简化Mockito的使用。 基本原理 Mockito API基于&#xff08;BDD&#xff09;Mockito类中聚集的静态方法&#xff08;大部分&#xff09;&#xff0c;然后进行非常流畅的链接方法调用。 可以使用模拟/间谍/给定/然后/验…

LeetCode 15 二进制中1的个数

原题 解题思路: 位运算 eor & -eor eor & (~eor 1) 取出数中最后一位的操作 class Solution { public:int hammingWeight(uint32_t n) {int ret0;while(n){n-(n & -n);//每次减n最后一位1 &#xff0c;减了多少次。就有多少个1ret;} return ret;} };…

java实现未读消息提醒_Android自定义View之未读消息提示

一个轻量级的仿微信未读消息提示大家好&#xff0c;我是接触安卓不久的小菜鸟&#xff0c;今天花了一晚上封装了一个类似微信未读消息提示的安卓控件。由于技术问题&#xff0c;所以功能不是很强大&#xff0c;没有动画&#xff0c;但是满足基本需求还是可以的。下面是示例图&a…

java 拼图_拼图推迟将Java 9的发布日期推迟到2017年

java 拼图由于Project Jigsaw的延迟&#xff0c;Java 9的发布日期被推迟到2017年 由于项目延迟的悠久历史&#xff0c;这可能不足为奇&#xff0c;但是看起来备受期待的拼图项目已被延迟。 再次。 好消息是&#xff0c;与上一次使用Java 8不同&#xff0c;它仍在Java 9的开发路…

java数据结构博客园_常见数据结构的Java实现

单链表的Java实现首先参考wiki上的单链表说明&#xff0c;单链表每个节点包含数据和指向链表中下一个节点的指针或引用。然后看代码import java.lang.*;public class SinglyLinkeList{Node start;public SinnglyLinkedList(){this.startnull;}public void addFront(Object newD…

jboss4 java_带有JBoss工具的OpenShift 3上的Java EE 7应用程序

jboss4 java您可以使用最新版本的JBoss Tools OpenShift插件在Eclipse中创建和管理OpenShift应用程序。 他们要么预先捆绑了最新的 JBoss Developer Studio&#xff08;9.0.0.GA&#xff09; &#xff0c;也可以将它们安装到现有的Eclipse Mars中。 这篇文章将引导您通过JBoss…

LeetCode 876. 链表的中间结点

原题链接 解题思路:快慢指针&#xff0c;快指针走两步&#xff0c;慢指针走一步。快指针到NULL慢指针自然到中间位置 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val(x), next(NULL) {}* };*/…

Java读取类路径下的JSON文件并转换为实体列表

使用 Jackson 库来读取类路径下的 JSON 文件并将其转换为对应实体列表。 在实际开发中可能在本地环境中需要调用别人的接口&#xff0c;别人的接口如果还没开发好或者本地环境不支持外部接口调用的时候&#xff0c;可以读取json文件来造数据&#xff0c;方便调试。 以Student…

java安全点_关于OopMap、SafePoint(安全点)以及安全区域

1.OopMap之前我们提到&#xff0c;在正式的GC之前总是需要进行可达性分析来查找内存中所有存活的对象&#xff0c;以便GC能够正确的回收已经死亡的对象。那么对于一个十分复杂的系统&#xff0c;每次GC的时候都要遍历所有的引用肯定是不现实的。因为在可达性分析的时候&#xf…

javaslang_使用Javaslang的Java 8中的功能数据结构

javaslangJava 8的lambda&#xff08;λ&#xff09;使我们能够创建出色的API。 它们极大地提高了语言的表达能力。 Javaslang利用lambda来基于功能模式创建各种新功能。 其中之一是功能性集合库&#xff0c;旨在替代Java的标准集合。 &#xff08;这只是鸟瞰图&#xff0c;您…

LeetCode 面试题 链表中倒数第K个点

解题思路&#xff0c;倒数第K个点&#xff0c;位于正数N-K1的位置。 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val(x), next(NULL) {}* };*/ class Solution { public:ListNode* getKthFromEn…

java调用kafka接口发送数据_Java调用Kafka生产者,消费者Api及相关配置说明

本次的记录内容包括&#xff1a;1.Java调用生产者APi流程2.Kafka生产者Api的使用及说明3.Kafka消费者Api的使用及说明4.Kafka消费者自动提交Offset和手动提交Offset5.自定义生产者的拦截器&#xff0c;分区器那么接下来我就带大家熟悉以上Kafka的知识说明1.Java调用生产者APi流…

java中的方法求和_在Java中模拟求和类型的巧妙解决方法

java中的方法求和在继续阅读实际文章之前&#xff0c;我想感谢令人敬畏的Javaslang库的作者Daniel Dietrich &#xff0c;他在我面前有了这个主意&#xff1a; lukaseder尝试使用静态方法<T&#xff0c;T1扩展T&#xff0c;... Tn扩展T> Seq <T> toSeq&#xff08…

java如何模拟请求_单元测试如何模拟用户请求

python web自动化测试设计构工具书40.9元包邮(需用券)去购买 >错误正当我高高兴兴写完后台c层的测试代码准备提交时&#xff0c;测试机器人报了很多401错误&#xff0c;把代码拉下来一看&#xff0c;原来当我写代码时&#xff0c;我的伙伴已经写好后台的拦截器了&#xff0c…

LeetCode 237. 删除链表中的节点

原题链接 解题思路&#xff1a;后面的的结点内容覆盖前面的结点内容 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val(x), next(NULL) {}* };*/ class Solution { public:void deleteNode(ListN…

java异步接口转同步接口_如果今天设计了Java:同步接口

java异步接口转同步接口Java已经走了很长一段路。 很长的路要走。 它带有早期设计决策中的所有“垃圾”。 一遍又一遍后悔的一件事是&#xff0c; 每个对象&#xff08;可能&#xff09;都包含一个监视器 。 几乎没有必要这样做&#xff0c;并且最终在Java 5中纠正了该缺陷&am…

LeetCode 83. 删除排序链表中的重复元素

原题链接 解法&#xff1a;通过一个指针从头到尾进行扫描 class Solution { public:ListNode* deleteDuplicates(ListNode* head) {if(!head)return nullptr;auto p1 head;while(p1->next){if(p1->next->val p1->val)p1->nextp1->next->next;else p1 …

java 使按钮被选中_java – 让我的单选按钮在Android中被选中

当我运行时,可以单击对话框,我的单选按钮不会像预期的那样被选中package edu.elon.cs.mobile;public class PTCalculator extends Activity{private RadioButton maleRadioButton;private RadioButton femaleRadioButton;private EditText ageEdit;private EditText pushUpsEdi…

后端 java ee_刷新器-Java EE 7后端十大功能

后端 java ee这是我的小型Java EE 7复习系列的第二部分。 在进行了简要概述的第一篇介绍之后&#xff0c;我决定请Arjan Tijms撰写有关Java EE 7中他最喜欢的后端新功能的信息。如果您关注Java EE领域&#xff0c;您将会知道Arjan。 他是Java EE开发人员&#xff0c;JSF和Secur…

java enum 报错_enum报错问题,求大神帮看下

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼public enum OrderStatusEnum {NOT_PAY("未付款", 0),NOT_YET_SHIPPEND("待发货", 1),YET_SHIPPEND("已发货", 2),HAS_BEEN_COMPLETED("已完成", 3),HAS_BEEN_CANANCELLED("已取消&q…