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 导致的额外长度)。
相关推荐
爱编程的化学家13 分钟前
代码随想录算法训练营第十一天--二叉树2 || 226.翻转二叉树 / 101.对称二叉树 / 104.二叉树的最大深度 / 111.二叉树的最小深度
数据结构·c++·算法·leetcode·二叉树·代码随想录
tqs_1234514 分钟前
redis zset 处理大规模数据分页
java·算法·哈希算法
吃着火锅x唱着歌1 小时前
LeetCode 1446.连续字符
算法·leetcode·职场和发展
愚润求学1 小时前
【贪心算法】day10
c++·算法·leetcode·贪心算法
吴秋霖1 小时前
主流反爬虫、反作弊防护与风控对抗手段
爬虫·算法·反爬虫技术
java1234_小锋2 小时前
Scikit-learn Python机器学习 - 分类算法 - K-近邻(KNN)算法
python·算法·机器学习
智者知已应修善业2 小时前
【矩阵找最大小所在位置】2022-11-13
c语言·c++·经验分享·笔记·算法·矩阵
shan&cen2 小时前
Day04 前缀和&差分 1109. 航班预订统计 、304. 二维区域和检索 - 矩阵不可变
java·数据结构·算法
手握风云-2 小时前
回溯剪枝的 “减法艺术”:化解超时危机的 “救命稻草”(二)
算法·机器学习·剪枝
QiZhang | UESTC2 小时前
JAVA算法练习题day11
java·开发语言·python·算法·hot100