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

相关推荐
快去睡觉~3 小时前
力扣73:矩阵置零
算法·leetcode·矩阵
岁忧4 小时前
(nice!!!)(LeetCode 每日一题) 679. 24 点游戏 (深度优先搜索)
java·c++·leetcode·游戏·go·深度优先
小欣加油4 小时前
leetcode 3 无重复字符的最长子串
c++·算法·leetcode
月盈缺7 小时前
学习嵌入式的第二十二天——数据结构——双向链表
数据结构·学习·链表
猿究院--王升7 小时前
jvm三色标记
java·jvm·算法
一车小面包7 小时前
逻辑回归 从0到1
算法·机器学习·逻辑回归
科大饭桶8 小时前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
tt5555555555558 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵
元亓亓亓9 小时前
LeetCode热题100--101. 对称二叉树--简单
算法·leetcode·职场和发展
躲在云朵里`9 小时前
深入理解数据结构:从数组、链表到B树家族
数据结构·b树