leetcode删除有序数组的重复项

直接模拟 采用覆盖的方式去删除重复项 很浪费时间和空间

class Solution {
    public int removeDuplicates(int[] nums) {
        int k = nums.length;
        int p1 = 0;
        int p2 = nums.length - 1;
        while(p1 < p2 && p1 != k -1){
            if(nums[p1] == nums[p1+1]){
                for(int i = p1;i < p2;i++){
                    nums[i] = nums[i+1];
                }
                k--;
            }else{
                p1++;
            }
        }
        return k;
    }
}

虽然过了 但还不够

优化算法

思路:采用计算重复个数 去移动第一个指针的位置 第二个指针用于去判断有几个重复遍历数组

  1. int p = 0;:这个变量 p 是一个指针,用来指示唯一元素应该放置的位置。在循环过程中,它会逐步指向新数组的末尾。
  2. int p1 = 0;:这是第一个指针,用于遍历原始数组。它从数组的开头开始。
  3. while (p1 < nums.length):这是一个循环,它确保我们在数组范围内进行操作,不会发生数组越界的情况。
  4. int p2 = p1 + 1;:这是第二个指针,用于查找连续重复的元素。它从第一个指针指向的元素的下一个位置开始。
  5. while (p2 < nums.length && nums[p1] == nums[p2]):这是一个内部循环,它会在找到连续重复的元素时进行迭代。当第二个指针 p2 指向的元素与第一个指针 p1 指向的元素相同时,就会继续向后移动。
  6. nums[p] = nums[p1];:当找到非重复的元素时,将它放置到唯一元素应该放置的位置 p。
  7. p++;:将唯一元素的指针向后移动一个位置,为下一个唯一元素做准备。
  8. p1 = p2;:将第一个指针移动到下一个非重复元素的位置,以继续遍历数组。
  9. 最后,返回 p,即唯一元素的数量,也就是新数组的长度。

class Solution {
    public int removeDuplicates(int[] nums) {
        int p = 0; // 指示唯一元素应该放置的位置
        int p1 = 0; // 第一个指针,用于遍历数组
        while (p1 < nums.length) { // 循环遍历数组
            int p2 = p1 + 1; // 第二个指针,用于查找连续重复的元素
            while (p2 < nums.length && nums[p1] == nums[p2]) { // 找到连续重复的元素
                p2++; // 移动第二个指针
            }
            nums[p] = nums[p1]; // 将当前非重复的元素放置到唯一元素的位置
            p++; // 移动唯一元素的指针
            p1 = p2; // 更新第一个指针到下一个非重复元素的位置
        }
        return p; // 返回唯一元素的数量
    }
}

差不多 可以接受 

  • 12
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值