LeetCode 面试经典150题 80.删除有序数组中的重复项II

题目

给你一个有序数组 nums ,请你**原地** 删除重复出现的元素,使得出现次数超过两次的元素只出现两次 ,返回删除后数组的新长度。

不要使用额外的数组空间,你必须在 原地修改输入数组并在使用 O(1) 额外空间的条件下完成。

思路

代码

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        int k = 2; // 保留位数
        int j = k - 1;  // 始终指向结果数组的最后一个位置
        for (int i = k; i < nums.length; i++) {
            // 注意和谁比较   j-k+1
            if (nums[j - k + 1] != nums[i]) {
                nums[++j] = nums[i];
            }
        }
        return j + 1;
    }
}

性能:时间复杂度 O(n) 空间复杂度O(1)

相关推荐
兩尛1 分钟前
45. 跳跃游戏 II
c++·算法·游戏
执风挽^13 分钟前
Python_func_basic
开发语言·python·算法·visual studio code
努力d小白17 分钟前
leetcode438.找到字符串中所有字母异位词
java·javascript·算法
tangchao340勤奋的老年?17 分钟前
ADS通信 C++ 设置通知方式读取指定变量
开发语言·c++·算法
wangluoqi18 分钟前
26.2.5练习总结
数据结构·算法
We་ct23 分钟前
LeetCode 1. 两数之和:两种高效解法(双指针 + Map)
前端·算法·leetcode·typescript·哈希算法
aini_lovee27 分钟前
基于MATLAB的材料晶粒组织生长与变化模拟:方法、实现与应用
开发语言·算法·matlab
t1987512830 分钟前
基于MATLAB的Copula对数似然值计算与参数验证
人工智能·算法·matlab
潇冉沐晴33 分钟前
div2 1064补题笔记(A~E)
笔记·算法
YuTaoShao34 分钟前
【LeetCode 每日一题】3640. 三段式数组 II——(解法二)DP
算法·leetcode·职场和发展