[LeetCode] Missing Ranges 缺失区间

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[LeetCode] Missing Ranges 缺失区间相关的知识,希望对你有一定的参考价值。

 

Given a sorted integer array where the range of elements are [0, 99] inclusive, return its missing ranges.
For example, given [0, 1, 3, 50, 75], return [“2”, “4->49”, “51->74”, “76->99”]

 

这道题让我们求缺失区间,跟之前那道Summary Ranges很类似,这道题让我们求缺失的空间,给了一个空间的范围[lower upper],缺失的空间的范围需要在给定的空间范围内。那么我最先想到的方法是这样的,将upper加入nums的末尾,然后用变量t初始赋值为lower,开始遍历数组nums,如果当前值和t相等,那么t自增1,如果当前值大于t,说明会有缺失区间存在,那么我们首先来判断upper是否大于当前值,如果大于,则当前值不能出现在区间里,我们还要判断当前值和t是否差1,若是,则说明缺失了一个数字t,如果不是差1,则缺失了区间[t nums[i]-1],然后我们将t赋为nums[i] + 1。如果upper小于等于当前值,说明这是最后一个缺失区间了,而且应该包含upper值,加完跳出循环即可,参见代码如下:

 

解法一:

class Solution {
public:
    vector<string> findMissingRanges(vector<int>& nums, int lower, int upper) {
        vector<string> res;
        nums.push_back(upper);
        int t = lower;
        string out;
        for (int i = 0; i < nums.size(); ++i) {
            if (nums[i] == t) ++t;
            else if (nums[i] > t) {
                if (upper > nums[i]) {
                    res.push_back(nums[i] - t == 1 ? to_string(t) : to_string(t) + "->" + to_string(nums[i] - 1));
                    t = nums[i] + 1;
                } else {
                    res.push_back(upper - t == 1 ? to_string(t) : to_string(t) + "->" + to_string(upper));
                    break;
                }
            }
        }
        return res;
    }
};

 

我们可以优化一下上面的代码,不给nums加数字,而且尽量少用一些if从句,那么我们在for循环里多增加一次循环,需要判断当i等于nums的长度时,将r赋为upper+1,否则当nums[i]小于等于upper时,将r赋为nums[i]。然后还是判断l和r的值,若相同,l自增1,否则当r大于l时,说明缺失空间存在,根据上面的判断方法相同,不过就是我们通过变量r把上面两个if情况合并了,参见代码如下:

 

解法二:

class Solution {
public:
    vector<string> findMissingRanges(vector<int>& nums, int lower, int upper) {
        vector<string> res;
        int l = lower;
        for (int i = 0; i <= nums.size(); ++i) {
            int r = (i < nums.size() && nums[i] <= upper) ? nums[i] : upper + 1;
            if (l == r) ++l;
            else if (r > l) {
                res.push_back(r - l == 1 ? to_string(l) : to_string(l) + "->" + to_string(r - 1));
                l = r + 1;
            }
        }
        return res;
    }
};

 

类似题目:

Summary Ranges

 

参考资料:

https://leetcode.com/discuss/29206/my-concise-java-accepted-solution

 

LeetCode All in One 题目讲解汇总(持续更新中...)

 

以上是关于[LeetCode] Missing Ranges 缺失区间的主要内容,如果未能解决你的问题,请参考以下文章

[LeetCode] 163. Missing Ranges 缺失区间

[Locked] Missing Ranges

Missing Ranges 解答

163. Missing Ranges

LC 163. Missing Ranges

163.Missing Ranges