LeetCode - #163 缺失的区间(会员题)


文章目录

    • 前言
    • [1. 描述](#1. 描述)
    • [2. 示例](#2. 示例)
    • [3. 答案](#3. 答案)
    • 关于我们

前言

本题为 LeetCode 的高级会员解锁题

我们社区陆续会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。

LeetCode 算法到目前我们已经更新到 162 期,我们会保持更新时间和进度(周一、周三、周五早上 9:00 发布),每期的内容不多,我们希望大家可以在上班路上阅读,长久积累会有很大提升。

不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。

难度水平:简单

1. 描述

给定一个排序的整数数组 nums,其中元素的范围在 闭区间 [lower, upper] 当中,返回不包含在数组中的缺失区间。

2. 示例

示例 1

复制代码
输入: nums = [0,1,3,50,75], lower = 0, upper = 99
输出: ["2","4->49","51->74","76->99"]
解释: 范围是:
[2,2] --> "2"
[4,49] --> "4->49"
[51,74] --> "51->74"
[76,99] --> "76->99"

示例 2

复制代码
输入: nums = [-1], lower = -2, upper = -1
输出: ["-2"]

约束条件:

  • -10^9 <= lower <= upper <= 10^9
  • 0 <= nums.length <= 100
  • 所有 nums 的值都是唯一的。

3. 答案

swift 复制代码
 class MissingRanges {
    func findMissingRanges(_ nums: [Int], _ lower: Int, _ upper: Int) -> [String] {     
        var res = [String]()
        
        guard !nums.isEmpty else {
            addRange(&res, lower, upper)
            return res
        }
        
        addRange(&res, lower, nums[0] - 1)
        
        for i in 1..<nums.count {
            addRange(&res, nums[i - 1] + 1, nums[i] - 1)
        }
        
        addRange(&res, nums[nums.count - 1] + 1, upper)
        
        return res
    }
    
    private func addRange(_ res: inout [String], _ start: Int, _ end: Int) {
        if start > end {
            return
        } else if start == end {
            res.append("\(end)")
        } else {
            res.append("\(start)->\(end)")
        }
    }
}
  • 主要思想:扫描数组,并将每个元素与前一个元素进行比较,生成相应的范围。
  • 时间复杂度: O(n)
  • 空间复杂度: O(1)

该算法题解的仓库:LeetCode-Swift

点击前往 LeetCode 练习

关于我们

我们是由 Swift 爱好者共同维护,我们会分享以 Swift 实战、SwiftUI、Swift 基础为核心的技术内容,也整理收集优秀的学习资料。

相关推荐
阿赛工作室2 小时前
mac系统使用Hbuilderx调试安装app
macos
weixin_462446237 小时前
Linux/Mac 一键自动配置 JAVA_HOME 环境变量(含 JDK 完整性校验)
java·linux·macos
Frank学习路上7 小时前
【Qt】问题记录ld: framework ‘AGL‘ not found on MacOS 26
开发语言·qt·macos
SoraLuna7 小时前
KuiklyUI for OpenHarmony 实战 02:Kuikly 工程创建与鸿蒙运行(Mac)
macos·华为·harmonyos
微信-since811928 小时前
【mac】 mac使用
macos
REDcker1 天前
macOS「系统数据」暴涨到 几百GB?一篇文章教你安全清理(含排查顺序)
macos
sysinside1 天前
macOS Sequoia 15.7.2 (24G325) 正式版 ISO、IPSW、PKG 下载
macos·sequoia
只是有点小怂1 天前
macOS 没有像 Windows 上的 MobaXterm 的工具
macos
小雨青年1 天前
环境准备 Windows Mac 下 Docker Desktop 的安装与镜像源加速
windows·macos·docker
数据知道1 天前
一文掌握 MongoDB 详细安装与配置(Windows / Linux / macOS 全平台)
linux·数据库·windows·mongodb·macos