• LeetCode 0228. 汇总区间


    【LetMeFly】228.汇总区间

    力扣题目链接:https://leetcode.cn/problems/summary-ranges/

    给定一个  无重复元素 的 有序 整数数组 nums

    返回 恰好覆盖数组中所有数字最小有序 区间范围列表 。也就是说,nums 的每个元素都恰好被某个区间范围所覆盖,并且不存在属于某个范围但不属于 nums 的数字 x

    列表中的每个区间范围 [a,b] 应该按如下格式输出:

    • "a->b" ,如果 a != b
    • "a" ,如果 a == b

     

    示例 1:

    输入:nums = [0,1,2,4,5,7]
    输出:["0->2","4->5","7"]
    解释:区间范围是:
    [0,2] --> "0->2"
    [4,5] --> "4->5"
    [7,7] --> "7"
    

    示例 2:

    输入:nums = [0,2,3,4,6,8,9]
    输出:["0","2->4","6","8->9"]
    解释:区间范围是:
    [0,0] --> "0"
    [2,4] --> "2->4"
    [6,6] --> "6"
    [8,9] --> "8->9"
    

     

    提示:

    • 0 <= nums.length <= 20
    • -231 <= nums[i] <= 231 - 1
    • nums 中的所有值都 互不相同
    • nums 按升序排列

    方法一:模拟

    记录上一个“区间”的开始元素(初始值是第一个元素),之后从第二个元素开始遍历

    如果这个元素和上个元素“不连续”(不等于上个元素+1),那么就在答案中加入这个区间(开始元素到上一个元素)

    • 时间复杂度 O ( n ) O(n) O(n)
    • 空间复杂度 O ( 1 ) O(1) O(1)

    AC代码

    C++
    class Solution {
    private:
        string num2str(int numBegin, int numEnd) {
            if (numBegin == numEnd) {
                return to_string(numBegin);
            }
            else {
                return to_string(numBegin) + "->" + to_string(numEnd);
            }
        }
    public:
        vector<string> summaryRanges(vector<int>& nums) {
            if (nums.empty())
                return {};
            
            vector<string> ans;
            int lastBeginNum = nums[0];
            for (int i = 1; i < nums.size(); i++) {
                if (nums[i] != nums[i - 1] + 1) {
                    ans.push_back(num2str(lastBeginNum, nums[i - 1]));
                    lastBeginNum = nums[i];
                }
            }
            ans.push_back(num2str(lastBeginNum, nums.back()));
            return ans;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    Python
    # from typing import List
    
    class Solution:
        def genStr(self, l: int, r: int) -> str:
            if l == r:
                return str(l)
            return str(l) + '->' + str(r)
        
        def summaryRanges(self, nums: List[int]) -> List[str]:
            if not nums:
                return []
            ans = []
            beginNum = nums[0]
            for i in range(1, len(nums)):
                if nums[i] !=  nums[i - 1] + 1:
                    ans.append(self.genStr(beginNum, nums[i - 1]))
                    beginNum = nums[i]
            ans.append(self.genStr(beginNum, nums[-1]))
            return ans
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    同步发文于CSDN,原创不易,转载请附上原文链接哦~
    Tisfy:https://letmefly.blog.csdn.net/article/details/126753220

  • 相关阅读:
    2023!6招玩转 Appium 自动化测试
    【milkv】添加LCD屏GC9306
    出海季收官,速来 Get 全球化发展实操手册
    记录第一个启动代码的诞生
    基于springboot+vue+elementui的游戏攻略分享平台
    传输层—TCP原理详解
    可视化学习:如何生成简单动画让图形动起来
    Fortinet详解如何量化网安价值,把握网安态势
    封装自己的jq myFullPage插件
    为安全带来光明:光耦继电器的 10 种救生应用
  • 原文地址:https://blog.csdn.net/Tisfy/article/details/126753220