LeetCode:2009. 使数组连续的最少操作数(排序 Java)

目录

[2009. 使数组连续的最少操作数](#2009. 使数组连续的最少操作数)

题目描述:

实现代码与解析:

[排序 + 去重 + 双指针](#排序 + 去重 + 双指针)

原理思路:

滑动窗口

原理思路:


2009. 使数组连续的最少操作数

题目描述:

给你一个整数数组 nums 。每一次操作中,你可以将 nums任意 一个元素替换成 任意整数。

如果 nums 满足以下条件,那么它是 连续的

  • nums 中所有元素都是 互不相同 的。
  • nums最大 元素与 最小 元素的差等于 nums.length - 1

比方说,nums = [4, 2, 5, 3]连续的 ,但是 nums = [1, 2, 3, 5, 6] 不是连续的

请你返回使 nums 连续最少 操作次数。

示例 1:

复制代码
输入:nums = [4,2,5,3]
输出:0
解释:nums 已经是连续的了。

示例 2:

复制代码
输入:nums = [1,2,3,5,6]
输出:1
解释:一个可能的解是将最后一个元素变为 4 。
结果数组为 [1,2,3,5,4] ,是连续数组。

示例 3:

复制代码
输入:nums = [1,10,100,1000]
输出:3
解释:一个可能的解是:
- 将第二个元素变为 2 。
- 将第三个元素变为 3 。
- 将第四个元素变为 4 。
结果数组为 [1,2,3,4] ,是连续数组。

提示:

  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 109

实现代码与解析:

排序 + 去重 + 双指针

java 复制代码
class Solution {
    public int minOperations(int[] nums) {
        int n =nums.length;
        // 排序
        Arrays.sort(nums);
        // 去重
        int t = 1;
        for (int i = 1; i < n; i++) {
            if (nums[i] != nums[i - 1]) {
                nums[t++] = nums[i];
            }
        }

        int res = n;

        for (int i = 0, j = 0; i < t; i++) {
            while (j < t && nums[j] - nums[i] <= n - 1) {
                j++;
            }
            res = Math.min(res, n - (j - i));
        }

        return res;

    }
}

原理思路:

nums最大 元素与 最小 元素的差等于 nums.length - 1,说明,数组中的数,一定是从最小值连续到最大值且没有重复值

所以,进行排序和去重。枚举最小值,找出在 nums[i] + n - 1 范围内的个数,不在范围内的就是需要修改的个数。

当然二分也可以求,就是求第一个大于nums[i]+n−1的位置j。

滑动窗口

java 复制代码
class Solution {
    public int minOperations(int[] nums) {
        int n =nums.length;
        // 排序
        Arrays.sort(nums);
        // 去重
        int t = 1;
        for (int i = 1; i < n; i++) {
            if (nums[i] != nums[i - 1]) {
                nums[t++] = nums[i];
            }
        }

        int res = 0;

        int l = 0;
        for (int r = 0; r < t; r++) {
            while (nums[l] < nums[r] - (n - 1)) {
                l++;
            }
            res = Math.max(res, r - l + 1);
        }
        return n - res;
    }
}

原理思路:

和上面的解法原理相同,只不过这里枚举的最大值,然后不在范围内的通过左端点过滤掉,也就是滑动窗口。

相关推荐
南山十一少33 分钟前
Spring Security+JWT+Redis实现项目级前后端分离认证授权
java·spring·bootstrap
427724002 小时前
IDEA使用git不提示账号密码登录,而是输入token问题解决
java·git·intellij-idea
chengooooooo2 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
李长渊哦2 小时前
常用的 JVM 参数:配置与优化指南
java·jvm
计算机小白一个2 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^3 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿5 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!5 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉5 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生5 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode