Leetcode 283 移动零

Leetcode 283 移动零

题目描述:

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

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

示例 1:

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

示例 2:

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

代码:

class Solution:

  def moveZeroes(self, nums: List[int]) -> None:

​    n=len(nums)

​    left=right=0

​    while right<n:

​      if nums[right]!=0:

​        nums[left],nums[right]=nums[right],nums[left]

​        left+=1

​      right+=1


解法:

使用双指针,左指针指向当前已经处理好的序列的尾部,右指针指向待处理序列的头部。右指针不断向右移动,当右指针指向非零数时,将左右指针指向的数进行交换,同时左指针右移。不难发现,左指针左边均为非零数,右指针左边直至左指针处均为零。

posted @ 2022-03-27 18:09  zhoupaopaoer  阅读(38)  评论(0)    收藏  举报