给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。
示例 1: 输入: nums = [0,1,0,3,12] 输出: [1,3,12,0,0] 示例 2: 输入: nums = [0] 输出: [0]
思路:
设置一个j,表示非0数的个数,循环遍历数组, 如果不是0,将非0值移动到第j位置,然后j+ 1 遍历结束之后,j值表示为非0的个数,再次遍历,从j位置后的位置此时都应该为0
代码:
class Solution { public void moveZeroes(int[] nums) { int n=nums.length; int j=0; int i=0; for(i=0;i<n;i++){ if(nums[i]!=0){ nums[j++]=nums[i]; } } for(i=j;i<n;i++){ nums[i]=0; } } }