<LeetCode天梯>Day011 移动零(传统法+双指针法) | 初级算法 | Python

简介: <LeetCode天梯>Day011 移动零(传统法+双指针法) | 初级算法 | Python

以下为我的天梯积分规则:


每日至少一题:一题积分+10分

若多做了一题(或多一种方法解答),则当日积分+20分(+10+10)

若做了三道以上,则从第三题开始算+20分(如:做了三道题则积分-10+10+20=40;做了四道题则积分–10+10+20+20=60)


初始分为100分

若差一天没做题,则扣积分-10分(周六、周日除外注:休息)

坚持!!!


初级算法

刷题目录

数组

image.png

题干

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。


示例:


输入: [0,1,0,3,12]

输出: [1,3,12,0,0]


说明:


必须在原数组上操作,不能拷贝额外的数组。

尽量减少操作次数。

删除+末尾候补法一

分析:


题干很简单,我们只需要在原数组上进行操作即可,越简单越好,减少操作的次数,才能做到最优化。

所以,我们先检索0的个数,然后将0移到末尾去,非零保持相对位置。

class Solution:
    def moveZeroes(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        n = len(nums)
    if zero > 0:
                for i in range(zero):
                    nums.remove(0) 
                nums.extend([0]*zero)

(⊙o⊙)…

image.png

感觉效果好像不是那么的好

image.png

image.png

删除+末尾候补法二

class Solution:
    def moveZeroes(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        n = len(nums)
    zero = 0
            for i in range(n):
                if nums[zero] == 0:
                    nums.pop(zero)  # 删除所在索引位的数值
                    nums.append(0)  # 末尾添0
                else:
                    zero += 1

今天实验室网有点差,不知道是不是这个原因,导致效果不怎么好,但是不应该的呀,哎

image.png

image.png

双指针法

那砸门再搞搞优化一下


咱们用经典双指针来实现循环交换移动位置,快指针和慢指针


使用双指针,左指针指向当前已经处理好的序列的尾部,右指针指向待处理序列的头部。


右指针不断向右移动,每次右指针指向非零数,则将左右指针对应的数交换,同时左指针右移。


注意到以下性质:


左指针左边均为非零数;

右指针左边直到左指针处均为零

因此每次交换,都是将左指针的零与右指针的非零数交换,且非零数的相对顺序并未改变。


image.png

class Solution:
    def moveZeroes(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        n = len(nums)
        fast = slow = 0
        while fast < n:
            if nums[fast] != 0:
                nums[slow], nums[fast] = nums[fast], nums[slow]
                slow += 1
            fast += 1

就很TM的离谱!!!

image.png

image.png

离谱,不过速度上去了

相关文章
|
2月前
|
存储 算法 JavaScript
怎么刷算法,leetcode上有哪些经典题目
怎么刷算法,leetcode上有哪些经典题目
16 0
|
2月前
|
算法
LeetCode刷题---21.合并两个有序链表(双指针)
LeetCode刷题---21.合并两个有序链表(双指针)
|
2月前
|
算法
LeetCode刷题---19. 删除链表的倒数第 N 个结点(双指针-快慢指针)
LeetCode刷题---19. 删除链表的倒数第 N 个结点(双指针-快慢指针)
|
2月前
|
存储 算法
LeetCode刷题---209. 长度最小的子数组(双指针-滑动窗口)
LeetCode刷题---209. 长度最小的子数组(双指针-滑动窗口)
|
2月前
|
存储 容器
LeetCode刷题---11. 盛最多水的容器(双指针-对撞指针)
LeetCode刷题---11. 盛最多水的容器(双指针-对撞指针)
|
2月前
|
算法
LeetCode刷题---167. 两数之和 II - 输入有序数组(双指针-对撞指针)
LeetCode刷题---167. 两数之和 II - 输入有序数组(双指针-对撞指针)
|
2月前
|
存储 算法
LeetCode刷题---75. 颜色分类(双指针,循环不变量)
LeetCode刷题---75. 颜色分类(双指针,循环不变量)
|
2月前
|
算法
LeetCode刷题---283. 移动零(双指针)
LeetCode刷题---283. 移动零(双指针)
|
7天前
|
API Python
[AIGC] 使用Python刷LeetCode:常用API及技巧指南
[AIGC] 使用Python刷LeetCode:常用API及技巧指南
|
12天前
|
算法
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
18 3