2023-08-26 LeetCode每日一题(汇总区间)

2023-08-26每日一题

一、题目编号

复制代码
228. 汇总区间

二、题目链接

点击跳转到题目位置

三、题目描述

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

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

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

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

示例 1:

示例 2:

提示:

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

四、解题代码

cpp 复制代码
class Solution {
public:
    vector<string> summaryRanges(vector<int>& nums) {
        vector<string> res;
        int n = nums.size();
        if(n == 0){
            return res;
        }
        if(n == 1){
            res.push_back(to_string(nums[0]));
            return res;
        }
        int left = nums[0];
        int right = nums[0];
        for(int i = 0; i < n; ++i){
            if(i == 0){
                continue;
            }
            if(nums[i] != nums[i-1] + 1){
                if(left == right){
                    res.push_back(to_string(left));
                } else{
                    res.push_back(to_string(left) + "->" + to_string(right));
                }
                left = nums[i];
                right = nums[i];
            } else{
                right = nums[i];
            }
        }
        if(left == right){
            res.push_back(to_string(left));
        } else{
            res.push_back(to_string(left) + "->" + to_string(right));
        }
    return res;
    }
};

五、解题思路

(1) 记录结果数组为res。有序整数数组的长度为n。

(2) n等于0的时候,输出空数组,n等于的时候,只有一个数。

(3) 记录区间left = nums[0],right = nums[0],这是初始化的过程。从i等于1开始遍历。

(4) 如果nums[i] 等于 nums[i-1] + 1,更新右端,如果不等于,则判断left和right是否相等。如果相等,区间为单一数字,如果不相等,则左端为left,右端为right,此时再次将left和right更新为nums[i] (当前遍历的位置)。

(5) 当一遍数组遍历完毕后还需要再判断一次left和right是否相等,按照(4)中所述的规则记录最后一个区间。

(6) 最后返回结果数组即可。

相关推荐
aigcapi3 小时前
RAG 系统的黑盒测试:从算法对齐视角解析 GEO 优化的技术指标体系
大数据·人工智能·算法
苏宸啊4 小时前
链式二叉树基操代码实现&OJ题目
数据结构
风筝在晴天搁浅4 小时前
hot100 25.K个一组翻转链表
数据结构·链表
柯慕灵4 小时前
7大推荐系统/算法框架对比
算法·推荐算法
adam-liu4 小时前
Fun Audio Chat 论文+项目调研
算法·语音端到端·fun-audio-chat
小十一再加一5 小时前
【初阶数据结构】栈和队列
数据结构
栀秋6665 小时前
你会先找行还是直接拍平?两种二分策略你Pick哪个?
前端·javascript·算法
如果你想拥有什么先让自己配得上拥有5 小时前
数学思想和数学思维分别都有什么?
线性代数·算法·机器学习
长安er5 小时前
LeetCode136/169/75/31/287 算法技巧题核心笔记
数据结构·算法·leetcode·链表·双指针
MarkHD6 小时前
智能体在车联网中的应用:第29天 多智能体完全合作场景的核心算法:从CTDE思想到VDN与MADDPG的深度解析
算法