力扣热题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
相关推荐
rit843249916 小时前
基于感知节点误差的TDOA定位算法
算法
m0_3722570216 小时前
ID3 算法为什么可以用来优化决策树
算法·决策树·机器学习
q***252116 小时前
SpringMVC 请求参数接收
前端·javascript·算法
Dream it possible!16 小时前
LeetCode 面试经典 150_图_克隆图(90_133_C++_中等)(深度优先:DFS)
c++·leetcode·面试·
数模加油站17 小时前
25认证杯C题成品论文第一弹【冲奖硬核+无盲点解析】
算法·数学建模·认证杯·25认证杯
MobotStone17 小时前
数字沟通之道
人工智能·算法
点云SLAM17 小时前
Boost库中Math 模块的插值(interpolation使用和示例
算法·插值·boost库·b-spline·akima 样条·单调三次样条·barycentric 插值
鸭子程序员17 小时前
c++ 算法
开发语言·c++·算法
Ghost-Face17 小时前
《逆袭导论》————初中生的宝书
算法
不会c嘎嘎17 小时前
算法百练,直击OFFER -- day5
c++·算法