LeetCode刷題:移動零

題目

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

示例:

輸入: [0,1,0,3,12]
輸出: [1,3,12,0,0]

說明:

必須在原數組上操作,不能拷貝額外的數組。
儘量減少操作次數。

題解
思路:把非零的都往前移,最後幾位補0
時間和內存消耗爲:
在這裏插入圖片描述
代碼爲:

	class Solution {
    public void moveZeroes(int[] nums) {
        int i=0;
        for(int num:nums){
            if(num!=0){
                nums[i++]=num;
            }
        }
        for(int j=i;j<nums.length;j++){
            nums[j]=0;
        }
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章