题解 | #删除升序数组的重复元素(二)#

删除升序数组的重复元素(二)

https://www.nowcoder.com/practice/5b617a77d7654dc193bfe5c2bdaf5cc8

python 语言用for循环边遍历边删除,用逆序或者切片的方式,可以通过小数据量的用例,有一个十万个元素的用例运行超时了。

class Solution:
    def removenums(self , nums: List[int]) -> int:
        n = len(nums)
        cur = nums[-1]
        count = 1
        for i in range(n-2,-1,-1):
            if nums[i] == cur:
                count += 1
                if count >= 3:
                    nums.remove(nums[i])
            else:
                cur = nums[i]
                count = 1
        return len(nums)
class Solution:
    def removenums(self , nums: List[int]) -> int:
        cur = nums[0]
        count = 1
        for i in nums[1:]:
            if i == cur:
                count += 1
                if count >= 3:
                    nums.remove(i)
            else:
                cur = i
                count = 1
        return len(nums)

全部评论

相关推荐

点赞 评论 收藏
分享
06-04 20:17
门头沟学院 Java
牛客713608542号:有的,我今天刚面了一个小厂,他们说刚好有缺人,就放出来了,成都的旅鸽,hxd不如去试试,但是是线下哇,不知道他们支不支持线上,如果有面记得多复习一下sql,我死在这一块上了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务