力扣每日练习(3.19)补

2024-03-21 09:12
文章标签 力扣 每日 练习 3.19

本文主要是介绍力扣每日练习(3.19)补,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

958. 二叉树的完全性检验

根据完全的定义,可以知道是最后一层的节点要尽可能靠近左边,那么不成立的条件就是最后一层的节点是这样的[1,4,56,null,13]
也就是第一个空节点后竟然还有非空节点,违背了完全。

所以采用层序遍历的方式,将每层的节点都检查是否null是连续的。这样不仅考虑了最后一层的情况,还考虑到了中间层有null的情况。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def isCompleteTree(self, root: Optional[TreeNode]) -> bool:# 层序遍历queue = [root]# 初始化标记is_empty = Falsewhile queue:level_size = len(queue)for _ in range(level_size):# 检查每个节点node = queue.pop(0)# 节点为空,则将指示变量设为Trueif node is None:is_empty = Trueelse: # 否则,检查指示变量是否为True,如果是,则代表前面有空节点,不是完全了if is_empty: return False# 不为空,继续检查左右子树,空的也要加queue.append(node.left)queue.append(node.right)return is_empty

543. 二叉树的直径

二叉树的直径不一定通过根节点,它可以是:
经过根节点的最长路径,这条路径由根节点的左子树的最大深度和右子树的最大深度组成。
完全位于左子树内的最长路径。
完全位于右子树内的最长路径。

因此,对于每个节点,我们需要计算两部分:
经过该节点的最长路径长度(这不是直径,除非该节点恰好是直径的根节点)。这等于该节点左子树的深度加上右子树的深度。
该节点子树的深度,以便于父节点计算经过自身的最长路径长度。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def diameterOfBinaryTree(self, root: Optional[TreeNode]) -> int:self.diameter = 0def depth(node):if not node:return 0left_depth = depth(node.left)  # 计算左子树的深度right_depth = depth(node.right)  # 计算右子树的深度# 更新直径self.diameter = max(self.diameter, left_depth + right_depth)# 返回节点的深度return max(left_depth, right_depth) + 1depth(root)  # 从根节点开始递归return self.diameter

662. 二叉树最大宽度

最大宽度,中间如果是空也记上。很自然想到层序遍历,但是最大宽度不能像层序那样只记录非空节点,所以要引入索引

可以将其视为一个满二叉树,其性质就是

在一个完全二叉树(或任意二叉树,但我们用完全二叉树的性质来帮助我们进行计算)中,如果我们假设根节点的索引为0,则对于任意一个节点,其左子节点的索引为2 * index + 1,其右子节点的索引为2 * index + 2,其中index是该节点的索引。

所以就根据其索引,遇到非空的节点的左右子树,直接在队列中增加其节点和索引。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def widthOfBinaryTree(self, root: Optional[TreeNode]) -> int:if not root: return 0max_width = 0queue = [(root, 0)]  # 队列中存储(节点,索引)while queue:level_size = len(queue)_, first_index = queue[0]  # 当前层第一个节点的索引_, last_index = queue[-1]  # 当前层最后一个节点的索引max_width = max(max_width, last_index - first_index + 1)for _ in range(level_size):node, index = queue.pop(0)# 利用满二叉树的性质if node.left:queue.append((node.left, index * 2 +1))if node.right:queue.append((node.right, index * 2 +2))return max_width

这篇关于力扣每日练习(3.19)补的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/832306

相关文章

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

【Rust练习】12.枚举

练习题来自:https://practice-zh.course.rs/compound-types/enum.html 1 // 修复错误enum Number {Zero,One,Two,}enum Number1 {Zero = 0,One,Two,}// C语言风格的枚举定义enum Number2 {Zero = 0.0,One = 1.0,Two = 2.0,}fn m

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

两数之和--力扣1

两数之和 题目思路C++代码 题目 思路 根据题目要求,元素不能重复且不需要排序,我们这里使用哈希表unordered_map。注意题目说了只对应一种答案。 所以我们在循环中,使用目标值减去当前循环的nums[i],得到差值,如果我们在map中能够找到这个差值,就说明存在两个整数的和为目标值。 如果没有找到,就将当前循环的nums[i]以及下标i放入map中,以便后续查

【每日刷题】Day113

【每日刷题】Day113 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 91. 解码方法 - 力扣(LeetCode) 2. LCR 098. 不同路径 - 力扣(LeetCode) 3. 63. 不同路径 II - 力扣(LeetCode) 1. 91. 解码方法 - 力扣(LeetCode) //思路:动态规划。 cl

力扣第347题 前K个高频元素

前言 记录一下刷题历程 力扣第347题 前K个高频元素 前K个高频元素 原题目: 分析 我们首先使用哈希表来统计数字出现的频率,然后我们使用一个桶排序。我们首先定义一个长度为n+1的数组,对于下图这个示例就是长度为7的数组。为什么需要一个长度为n+1的数组呢?假如说总共有三个数字都为1,那么我们需要把这个1放在数组下标为3的位置,假如说数组长度为n,对于这个例子就是长度为3,那么它的