给定一个数组 nums
,编写一个函数将所有 0
移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入:[0,1,0,3,12]
输出:[1,3,12,0,0]
说明:
- 必须在原数组上操作,不能拷贝额外的数组。
- 尽量减少操作次数
思路:因为不能拷贝额外的数组,那么类似于定义两个指针,不断地维护这两个指针,swap交换数据。
class Solution {
public:
void moveZeroes(vector<int>& nums) {
int end=1;
int begin=0;
for(int i=0;i<nums.size();i++)
{
if (end==nums.size())
{
return;
}
if(nums[begin]==0)
{
if(nums[end]!=0)
{
/* int temp=nums[end];
nums[end]=nums[begin];
nums[begin]=temp;*/
swap(nums[begin],nums[end]);
end++;
begin++;
}
else{
end++;
if(end==nums.size())
return ;
i--;
}
}
else
{
end++;
begin++;
}
}
}
};