練習題32-移動零

原題目:
給定一個數組 nums,編寫一個函數將所有 0 移動到數組的末尾,同時保持非零元素的相對順序。

示例:
輸入: [0,1,0,3,12]
輸出: [1,3,12,0,0]
說明:
必須在原數組上操作,不能拷貝額外的數組。
儘量減少操作次數。

思路:
將數字不等於0的數字按遍歷順序依次從前往後存,然後如果不等於0的數字的數量小於數組長度的話,將這個數字後面的下標值置爲0.

代碼:

class Solution {
public:
    void moveZeroes(vector<int>& nums) {
    int i = 0,j = 0;
    for(i = 0 ; i < nums.size();i++)
    {
        if(nums[i] != 0)
        {
            nums[j++] = nums[i];
        }
    }
    while(j < nums.size())
    {
        nums[j++] = 0;
    }
    }
};

練習題31(兩道差不多類型的題目) -缺失數字和只出現一次的數字

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章