Leetcode80. 删除排序数组中的重复项 II

本文介绍了解决LeetCode80题的方法,该题要求在原地删除排序数组中的重复项,使每个元素最多出现两次,并返回新长度。通过双指针和计数方法,实现O(1)额外空间复杂度下的高效解决方案。

Leetcode80. 删除排序数组中的重复项 II

题目:
相似题目:Leetcode26. 删除排序数组中的重复项
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。

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

给定 nums = [1,1,1,2,2,3],
函数应返回新长度 length = 5, 并且原数组的前五个元素被修改为 1, 1, 2, 2, 3 。
你不需要考虑数组中超出新长度后面的元素。

示例 2:

给定 nums = [0,0,1,1,1,1,2,3,3],
函数应返回新长度 length = 7, 并且原数组的前五个元素被修改为 0, 0, 1, 1, 2, 3, 3 。
你不需要考虑数组中超出新长度后面的元素。

题解:

  1. 我们使用了两个指针, j j j 是遍历指针,指向当前遍历的元素; i i i 指向下一个要覆盖元素的位置。
  2. 同样,我们用 count 记录当前数字出现的次数。count 的最小计数始终为 1。
  3. 我们从索引 1 开始一次处理一个数组元素。
  4. 若当前元素与前一个元素相同,即 n u m s [ j ] = = n u m s [ j − 1 ] nums[j]==nums[j-1] nums[j]==nums[j1],则 count++。若 count > 2,则说明遇到了多余的重复项。在这种情况下,我们只向前移动 j j j,而 i i i不动。
  5. 若 count <=2,则我们将 j j j 所指向的元素移动到 i i i 位置,并同时增加 i i i j j j
  6. 若当前元素与前一个元素不相同,即 n u m s [ j ] ! = n u m s [ j − 1 ] nums[j] != nums[j - 1] nums[j]!=nums[j1],说明遇到了新元素,则我们更新 count = 1,并且将该元素移动到 i i i位置,并同时增加 i i i j j j
  7. 当数组遍历完成,则返回 i i i

java代码:

 /**
     * @param nums
     * @return
     */
    public static int removeDuplicates(int[] nums) {
        int count = 1;
        if (nums == null || nums.length == 0) {
            return 0;
        }
        int i = 1;
        for (int j = 1; j < nums.length; j++) {
            if (nums[j] == nums[j-1]) {
                count++;
            } else {
                count=1;
            }
            if(count<=2){
                nums[i]=nums[j];
                i++;
            }
        }
        return i;
    }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值