思路:将所有的零删除并计数,最后再加上就行了,不用我代码里的新的vector能大量节省空间
class Solution {
public:
void moveZeroes(vector<int>& nums) {
vector<int> an;
int l = nums.size();
int cnt = 0; //0的个数
for(int i = 0; i < l; i++){
if(nums[i] == 0){
cnt++;
}else{
an.push_back(nums[i]);
}
}
for(int i = 0; i < cnt; i++){
an.push_back(0);
}
nums = an;
}
};
版权声明:本文为weixin_44104745原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。