Python3_Leetcode #26 删除有序数组中的重复项

给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。

不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

理解:只需要返回长度,不需要返回数组

 

 

思路:

双指针思路:

设置两个值,分别代表两个指针

一个左指针,一个右指针

 

1. 使用right指针遍历整个数组

2.如果right对应的值比左指针的大,则left +1 ,且把右指针的值赋予当前左指针所指,right++

3.如果右指针和左指针相同,则不做操作,right++

4.最后返回左指针+1,因为都是从0 开始的。

 

代码:

 

class Solution:
    def removeDuplicates(self, nums: List[int]) -> int:

        if len(nums) == 0:
            return 0
        

        left = 0

        for right in range(len(nums)):
            
            
            if nums[left] < nums[right]:
                left +=1
                nums[left] = nums[right]
            

        return left+1

 

posted @ 2021-07-18 16:06  lms21  阅读(111)  评论(0)    收藏  举报