给定一个升序排列的数组 nums,请原地删除重复出现的元素
时间: 2023-02-08 16:15:31 浏览: 153
删除排序链表中的重复元素
如果要在原地删除重复出现的元素,可以使用双指针法。首先,初始化两个指针 i 和 j,其中 i 是慢指针,j 是快指针。然后,遍历数组,如果 nums[i] 等于 nums[j],则递增 j,直到 nums[j] 不等于 nums[i]。接着,将 nums[j] 赋值给 nums[i+1],并递增 i。重复上述过程,直到遍历完整个数组。
例如,给定数组 [0,0,1,1,1,2,2,3,3,4],则原地删除重复出现的元素后,数组变为 [0,1,2,3,4],并返回新数组的长度 5。
算法的时间复杂度为 O(n),空间复杂度为 O(1)。
示例代码(使用 Python 语言)如下:
```
def removeDuplicates(nums):
if not nums:
return 0
i = 0
for j in range(1, len(nums)):
if nums[i] != nums[j]:
i += 1
nums[i] = nums[j]
return i + 1
```
阅读全文