1.题目
LeetCode: 283. 移动零
【easy】
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数。
2.解题
方法一:暴力法
java:
class Solution {
public void moveZeroes(int[] nums) {
int len = nums.length;
int n = 0;
for(int i = 0; i < len - n; i++){
if(nums[i] == 0){
n++;
for(int j = i; j < len - n; j++){
nums[j] = nums[j+1];
}
nums[len - n] = 0;
}
if(nums[i] == 0) i--;
}
}
}
方法二:方法一的简洁版
java:
将非零元素放入数组前端,最后补充0.
class Solution {
public void moveZeroes(int[] nums) {
int idx = 0;
for (int num : nums) {
if (num != 0) nums[idx++] = num;
}
while (idx < nums.length) {
nums[idx++] = 0;
}
}
}
时间复杂度:O(n)
空间复杂度:O(1)