LeetCode 26. 删除排序数组中的重复项(python)

题目链接

题目描述:

给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。

不要使用额外的数组空间,你必须在原地修改输入数组并在使用 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。

你不需要考虑数组中超出新长度后面的元素。

解题思路:

从后向前比较每一个字符是否与其前一个相同,相同则删去这个数字
从后向前移除不用移动数组中其他元素,也不会带来下标的改变

class Solution(object):
    def removeDuplicates(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        for i in range(len(nums)-1,0,-1):
            if nums[i]==nums[i-1]:
                del nums[i]
        return len(nums)

在这里插入图片描述
评论区答案:
1.不删除元素,修改数组中的数字

        k = 1
        for i in range(1, len(nums)):
            if nums[i] != nums[i - 1]:
                nums[k] = nums[i]
                k += 1
        return k

2.设置双指针,同样是原地修改数组,不删除元素

        if len(nums)==0 or len(nums)==1:
            return len(nums)
        slow, fast = 0, 1
        while fast < len(nums):
            if nums[slow] != nums[fast]:
                nums[slow+1] = nums[fast]
                slow += 1
                fast += 1
            else:
                fast += 1
        return slow+1

你可能感兴趣的:(leetcode)