关于我们

质量为本、客户为根、勇于拼搏、务实创新

< 返回新闻公共列表

LeetCode - #56 合并区间(Top 100)

发布时间:2023-06-29 18:01:04
前言 本题为 LeetCode 前 100 高频题 我们社区陆续会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。 LeetCode 算法到目前我们已经更新了 55 期,我们会保持更新时间和进度(周一、周三、周五早上 9:00 发布),每期的内容不多,我们希望大家可以在上班路上阅读,长久积累会有很大提升。 不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。 难度水平:中等 1. 描述 以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。 2. 示例 示例 1 输入:intervals = [[1,3],[2,6],[8,10],[15,18]] 输出:[[1,6],[8,10],[15,18]] 解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6]. 示例 2 输入:intervals = [[1,4],[4,5]] 输出:[[1,5]] 解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。 约束条件: 1 <= intervals.length <= 10^4 intervals[i].length == 2 0 <= starti <= endi <= 10^4 3. 答案 /** * Definition for an interval. * public class Interval { * public var start: Int * public var end: Int * public init(_ start: Int, _ end: Int) { * self.start = start * self.end = end * } * } */ class MergeIntervals { func merge(intervals: [Interval]) -> [Interval] { var result = [Interval]() let intervals = intervals.sorted { if { mathJaxContainer[0]}1.start { return { mathJaxContainer[1]}1.start } else { return { mathJaxContainer[2]}1.end } } for interval in intervals { guard let last = result.last else { result.append(interval) continue } if last.end < interval.start { result.append(interval) } else { last.end = max(last.end, interval.end) } } return result } } 主要思想:对原始的间隔进行排序,然后一个接一个地添加它们。 时间复杂度: O(nlogn) 空间复杂度: O(n) 该算法题解的仓库:LeetCode-Swift 点击前往 LeetCode 练习 关于我们 我们是由 Swift 爱好者共同维护,我们会分享以 Swift 实战、SwiftUI、Swift 基础为核心的技术内容,也整理收集优秀的学习资料。 后续还会翻译大量资料到我们公众号,有感兴趣的朋友,可以加入我们。

/template/Home/leiyu/PC/Static