【leetcode】【80】Remove Duplicates from Sorted Array II

本文介绍了一种改进的去重算法,该算法允许数组中的每个元素最多重复两次,并保持数组的排序特性。通过双指针技术实现,具体展示了如何在遍历过程中更新数组并返回满足条件的数组长度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、问题描述

Follow up for "Remove Duplicates":
What if duplicates are allowed at most twice?

For example,
Given sorted array nums = [1,1,1,2,2,3],

Your function should return length = 5, with the first five elements of nums being 1122 and 3. It doesn't matter what you leave beyond the new length.

二、问题分析

题目要求最终的数组中前边部分满足要求即可,与Remove Duplicates一样,说明还是把后边的满足条件的数字往前挪。鉴于该题要求相同数字不能超过两次,显然如果还和Remove Duplicates一样使用一个指针来遍历很难满足要求,那么我们可以考虑双指针方法。从这个例子[1,1,1,2,2,3]来分析,前两个元素不需要管,从第三个数字来看,我们可以设置两个指针pre,cur,将cur指向第三个元素,将pre指向第二个元素,显然只有当nums[cur]==nums[pre]&&nums[cur]==nums[pre-1]的时候我们需要将cur继续往后移动寻找不同的元素;这时nums[cur]==2,不满足之前的判断条件,那么需要将2覆盖pre之后的元素,所以数组变为了[1,1,2,2,2,3],这时pre指向第一个2,cur指向第三个2,继续执行判断条件,pre可以++,这时虽然讲第三个2覆盖了第二个2因为是循环随意可能会出现同值覆盖的情况,然后继续执行后面的。有点啰嗦,看代码。

三、Java AC代码

public int removeDuplicates(int[] nums) {
        if (nums.length <= 2)
            return nums.length;
 
        int prev = 1; // point to previous
        int curr = 2; // point to current
 
        while (curr < nums.length) {
            if (nums[curr] == nums[prev] && nums[curr] == nums[prev - 1]) {
                curr++;
            } else {
                prev++;
                nums[prev] = nums[curr];
                curr++;
            }
        }
 
        return prev + 1;
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值