# [283] 移动零

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

示例:

输入: [0,1,0,3,12]

输出: [1,3,12,0,0]

说明:

必须在原数组上操作,不能拷贝额外的数组。

尽量减少操作次数。

因为是原地算法,因此考虑用快慢指针。

快指针不停向后遍历数组,慢指针指向数组第一个有0的位置。

若快指针指向的值不为0,则交换快慢指针的值,并将慢指针+1,指向下一个0的位置(快慢指针之间的值必然全为0)

function moveZeroes(nums: number[]): void {
  const len = nums.length;
  // 指针每次指向第一个零的位置
  let point = 0;
  for (let i = 0; i < len; i++) {
    if (nums[i] !== 0) {
      const temp = nums[i];
      nums[i] = nums[point];
      nums[point] = temp;
      point += 1;
    }
  }
}