力扣热题100_双指针_283_移动零


题目链接

283. 移动零

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

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例 1:

输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]
示例 2:

输入: nums = [0]
输出: [0]

解题思路

1.快慢指针slow、fast都初始化为0;
2.若fast值小于nums长度,则进行循环遍历;
2(1).如果fast所在nums索引不为0,fast所在nums索引与slow所在索引交换位置,并slow+=1处理;
2(2).如果fast所在nums索引为0,fast+=1处理

解题代码

class Solution:
    def moveZeroes(self, nums: List[int]) -> None:
        slow = 0
        fast = 0
        while fast < len(nums):
            if nums[fast] != 0:
                nums[slow], nums[fast] = nums[fast], nums[slow]
                slow += 1
            fast += 1
        return nums

相关推荐

  1. 100_指针_283_移动

    2024-02-10 08:12:01       60 阅读
  2. 283移动(快慢指针

    2024-02-10 08:12:01       35 阅读
  3. LeetCode 100——283. 移动

    2024-02-10 08:12:01       62 阅读
  4. LeetCode-100283.移动

    2024-02-10 08:12:01       39 阅读
  5. 283.移动

    2024-02-10 08:12:01       55 阅读
  6. -283. 移动

    2024-02-10 08:12:01       47 阅读
  7. 283. 移动

    2024-02-10 08:12:01       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-10 08:12:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-10 08:12:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-10 08:12:01       82 阅读
  4. Python语言-面向对象

    2024-02-10 08:12:01       91 阅读

热门阅读

  1. 力扣-260. 只出现一次的数字 III

    2024-02-10 08:12:01       46 阅读
  2. 2.8 假期作业

    2024-02-10 08:12:01       46 阅读
  3. virtio笔记

    2024-02-10 08:12:01       50 阅读
  4. django中实现数据迁移

    2024-02-10 08:12:01       43 阅读