文章目录
- 题目链接
- 解题思路
- 解题代码
题目链接
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 = 0fast = 0while fast < len(nums):if nums[fast] != 0:nums[slow], nums[fast] = nums[fast], nums[slow]slow += 1fast += 1return nums