输入:nums = [1,1,2]
输出:2, nums = [1,2]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。
输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。
双指针
#左指针与右指针不相同,
#则左指针移动到下一个位置,
#并将右指针的数字替换给左指针
class Solution:
def removeDuplicates(self, nums: List[int]) -> int:
left = 0
for right in range(1,len(nums)):
if nums[left] != nums[right]:
left +=1
nums[left]=nums[right]
return left+1