力扣热题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处理

解题代码

python 复制代码
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
相关推荐
xsh21944 分钟前
贪心算法套路模板+详细适用场景+经典题目清单
算法
白熊1881 小时前
【机器学习基础】机器学习入门核心算法:逻辑回归(Decision Tree)
算法·机器学习·逻辑回归
wen__xvn1 小时前
DFS入门刷题c++
c++·算法·深度优先
ruanjiananquan992 小时前
哈希算法:原理、应用、安全演进与推荐
算法·安全·哈希算法
Matlab仿真实验室3 小时前
基于Matlab实现各种光谱数据预处理
开发语言·算法·matlab·各种光谱数据预处理
姬公子5214 小时前
leetcode hot100刷题日记——21.不同路径
算法·leetcode
不会敲代码的灵长类4 小时前
机器学习算法-决策树
算法·决策树·机器学习
姬公子5214 小时前
leetcode hot100刷题日记——22.只出现一次的数字
算法·leetcode·职场和发展
心软且酷丶4 小时前
leetcode:1688. 比赛中的配对次数(python3解法,数学相关算法题)
python·算法·leetcode
緈福的街口4 小时前
【leetcode】977. 有序数组的平方
算法·leetcode·职场和发展