移动零
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数。
解法一
- 计算0的个数
- 去掉一个0
- 加入一个0
class Solution(object):
def moveZeroes(self, nums):
for i in range(nums.count(0)):
nums.remove(0)
nums.append(0)
return nums
解法二
- j为0的位置,i为非零位置
- 遇到为零的位置,i+1,遇到非零的位置,i,j交换值
class Solution(object):
def moveZeroes(self, nums):
j=0
for i in range(len(nums)):
if nums[i]!=0:
nums[j],nums[i]=nums[i],nums[j]
j+=1
return nums