leetcode 随机刷题记录 283移动零

思路:将所有的零删除并计数,最后再加上就行了,不用我代码里的新的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版权协议,转载请附上原文出处链接和本声明。