Python删除有序数组的重复项(附其他语言实现)

共 2019字,需浏览 5分钟

 ·

2021-12-12 08:14

点击上面“蓝字”关注我们!



给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。


示例 1:输入:nums = [1,1,2] 输出:2, nums = [1,2]

示例 2:输入:nums = [0,0,1,1,1,2,2,3,3,4] 输出:5, nums = [0,1,2,3,4]


解题思路


注意为有序数组,把数组nums分成两个数组,一个新的无重复元素的数组nums[0:i],一个数组nums[j, len(nums)]


  • 采用双指针,一个指针j指向数组nums[j, len(nums)],当nums[j] == nums[i]时,指针向右移;

  • 一个指针i指向新的无重复元素的数组nums[0:i],当nums[j] != nums[i]时,新数组增加长度,i=i+1,nums[i] = nums[j]

  • 得到新的数组nums[0:i],返回新数组的长度i+1


set 就是为了实现去重的。但是要求进行原地操作,并且时间复杂度是 O(1),因此就不能开辟另外的空间。则必须有一个指针指向当前需要把结果放在哪个位置,还要一个指针指向当前应该放到哪个元素。

代码实现


python/

class Solution:    def removeDuplicates(self, nums):        i = 0        for j in range(1, len(nums)):            if nums[j] != nums[i]:                i += 1                nums[i] = nums[j]        return i + 1

C/

int removeDuplicates(int* nums, int numsSize){    if(numsSize == 0){return 0;}    int slow = 0, fast = 1;    while(fast < numsSize){        if(nums[fast] != nums[slow]){            slow = slow + 1;            nums[slow] = nums[fast];        }        fast = fast + 1;    }    return slow + 1;}

C++/

class Solution {public:    int removeDuplicates(vector& nums) {        const int N = nums.size();        if (N == 0) return 0;        int left = 0;        for (int right = 1; right < N; ++right) {            if (nums[left] != nums[right]) {                nums[++left] = nums[right];            }        }        return left + 1;    }};

java/

class Solution {    public int removeDuplicates(int[] nums) {        int i = 0;        for(int j = 0; j < nums.length; j++){            if(nums[j] != nums[i]){                nums[++i] = nums[j];            }        }        return i + 1;    }}
【以往文章荟萃】

你需要的也许就在这里

只需要回头望望

我在这里等你哟

浏览 44
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报