Skip to content
Rain Hu's Workspace
Go back

[LeetCode] 2009. Minimum Number of Operations to Make Array Continuous

Rain Hu
class Solution {
public:
    int minOperations(vector<int>& nums) {
        sort(nums.begin(), nums.end());
        int left = 0, right = 0, n = nums.size(), res = 0;
        int curr = 0;
        while (right < n) {
            while (right < n - 1 && nums[right] == nums[right + 1]) right++;
            if (nums[right] - nums[left] > n-1) {
                while (left < n - 1 && nums[left] == nums[left + 1]) left++;
                left++;
                curr--;
            }
            right++;
            curr++;
            res = max(res, curr);
        }
        return n - curr;
    }
};

Share this post on:

Previous
[LeetCode] 1610. Maximum Number of Visible Points
Next
[LeetCode] 2106. Maximum Fruits Harvested After at Most K Steps