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) 最后返回结果数组即可。

相关推荐
wuweijianlove14 分钟前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong22 分钟前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志23 分钟前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光1 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_111 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg1 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒2 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾2 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
SatVision炼金士2 小时前
合成孔径雷达干涉测量(InSAR)沉降监测算法体系
算法