Leetcode打卡:不含特殊楼层的最大连续楼层数

执行结果:通过

题目 2274 不含特殊楼层的最大连续楼层数

Alice 管理着一家公司,并租用大楼的部分楼层作为办公空间。Alice 决定将一些楼层作为 特殊楼层 ,仅用于放松。

给你两个整数 bottomtop ,表示 Alice 租用了从 bottomtop(含 bottomtop 在内)的所有楼层。另给你一个整数数组 special ,其中 special[i] 表示 Alice 指定用于放松的特殊楼层。

返回不含特殊楼层的 最大 连续楼层数。

示例 1:

复制代码
输入:bottom = 2, top = 9, special = [4,6]
输出:3
解释:下面列出的是不含特殊楼层的连续楼层范围:
- (2, 3) ,楼层数为 2 。
- (5, 5) ,楼层数为 1 。
- (7, 9) ,楼层数为 3 。
因此,返回最大连续楼层数 3 。

示例 2:

复制代码
输入:bottom = 6, top = 8, special = [7,6,8]
输出:0
解释:每层楼都被规划为特殊楼层,所以返回 0 。

提示

  • 1 <= special.length <= 105
  • 1 <= bottom <= special[i] <= top <= 109
  • special 中的所有值 互不相同

代码以及解题思路

代码

class Solution:
    def maxConsecutive(self, bottom: int, top: int, special: List[int]) -> int:
        return max(y - x for x, y in pairwise([bottom - 1] + sorted(special) + [top + 1])) - 1

解题思路

  1. 理解题意
    • bottomtop 定义了查找连续整数序列的范围。
    • special 列表包含了在这个范围内的一些特殊数字,这些数字可以构成连续整数序列的一部分。
  2. 处理边界情况
    • 在开始计算之前,为了处理边界情况,我们在 special 列表的前后分别添加 bottom - 1top + 1。这两个数字不在目标范围内,但这样做可以帮助我们计算从 bottom 开始到第一个特殊数字以及从最后一个特殊数字到 top 结束之间的连续整数序列长度。
  3. 排序
    • special 列表进行排序,确保数字是按升序排列的。这是因为在连续整数序列中,每个数字都应该比前一个数字大1。
  4. 计算连续序列长度
    • 使用 pairwise 函数(来自 itertools 模块,但题目描述中未明确提及,可能是假设已知)来计算相邻元素之间的差值。pairwise 函数会返回一个迭代器,其中每个元素是一个元组,包含列表中的相邻项 (x, y)
    • 对每个 (x, y) 元组,计算 y - x,这将给出从 xy(不包括 y)之间的连续整数个数。注意,由于我们在列表的开头和结尾添加了 bottom - 1top + 1,这里的 y - x 实际上表示的是从 x+1y-1 的连续整数个数(因为我们要找的是严格大于前一个数的连续整数序列)。
  5. 找出最大长度
    • 使用 max 函数找出所有计算出的连续整数序列长度的最大值。
  6. 调整结果
    • 由于我们在计算长度时考虑了序列的起始和结束数字(即 x+1y-1),而题目要求的是序列中数字的数量,因此需要从最大值中减去1来得到最终答案。这是因为我们在计算长度时包括了序列两端的边界效应(即添加的 bottom - 1top + 1 导致的额外长度)。
相关推荐
Felix_12154 小时前
2025 西电软工数据结构机考 Tip (By Felix)
算法
飞yu流星5 小时前
C++ 函数 模板
开发语言·c++·算法
pursuit_csdn5 小时前
力扣 74. 搜索二维矩阵
算法·leetcode·矩阵
labuladuo5205 小时前
洛谷 P8703 [蓝桥杯 2019 国 B] 最优包含(dp)
算法·蓝桥杯·动态规划
Milk夜雨6 小时前
C语言冒泡排序教程简介
数据结构·算法·排序算法
委婉待续6 小时前
redis的学习(三)
数据结构·算法
一直学习永不止步6 小时前
LeetCode题练习与总结:随机翻转矩阵--519
java·数学·算法·leetcode·哈希表·水塘抽样·随机化
xiao--xin6 小时前
LeetCode100之组合总和(39)--Java
java·开发语言·算法·leetcode·回溯
测试杂货铺6 小时前
selenium遇见伪元素该如何处理?
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
IT猿手8 小时前
部落竞争与成员合作算法(CTCM)求解5个无人机协同路径规划(可以自定义无人机数量及起始点),MATLAB代码
深度学习·算法·机器学习·matlab·无人机·无人机、