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

69 篇文章 1 订阅
63 篇文章 0 订阅

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

不要使用额外的数组空间,你必须在原地修改输入数组并在使用 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 。

你不需要考虑数组中超出新长度后面的元素。

方法:遍历重写
思路:直接遍历原数组,前两个直接保持原样,然后从第三个数字开始,判断是否和数组当前重新后的当前坐标i-2处的数组是否相等,不等则直接写入当前位置,然后位置指针加一,继续下个数值判断,否则就直接保持i不变,继续遍历数组;
1,数组从i=0指针处开始重新写入;
2,前两位保持不变,从第三个数开始判断,其是否和当前指针i-2处的值相等;
3,不等直接将此数值重写到数组i处,然后i+1,否则继续遍历重复上述判断即可;
4,返回重写的数组段,也就是i即可;

class Solution {
    public int removeDuplicates(int[] nums) {
        //用原地算法,并且使用常数空间
        //遍历数组,从头开始重新填充,最多只保存两个相同数,一直往后覆盖,直到遍历完成
        int i = 0;//记录当前坐标,也就是当前覆盖了的数组长度
        for (int n : nums) {
            //长度小于2时直接返回即可,当前数字,一直和数组当前坐标i -2 比较,大就直接保存
            if (i < 2 || nums[i-2] != n)
                nums[i ++] = n;
        }
        return i;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值