题目
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/move-zeroes
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
示例
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数。
解答
方法一
将数组中所有0删掉,然后删掉了几个就在末尾追加几个。
class Solution:
def moveZeroes(self, nums):
len_nums = len(nums)
while nums.count(0) > 0:
nums.remove(0)
new_len = len(nums)
for i in range(len_nums - new_len):
nums.append(0)
方法二
使用双指针的方法解,就很便捷。
class Solution:
def moveZeroes(self, nums):
left = 0
right = 1
while right < len(nums):
if nums[left] == 0 and nums[right] != 0:
nums[left], nums[right] = nums[right], nums[left]
left += 1
right += 1
elif nums[left] == 0 and nums[right] == 0:
right += 1
else:
left += 1
right += 1
if __name__ == '__main__':
li = [0, 1, 0, 3, 12]
Solution().moveZeroes(li)
print(li)