JavaScript——在原數組上移除數組元素

題目:給定一個數組 nums 和一個值 val,你需要原地移除所有數值等於 val 的元素,返回移除後數組的新長度。

          不要使用額外的數組空間,你必須在原地修改輸入數組並在使用 O(1) 額外空間的條件下完成。

          元素的順序可以改變。你不需要考慮數組中超出新長度後面的元素。

示例 1:

給定 nums = [3,2,2,3], val = 3,

函數應該返回新的長度 2, 並且 nums 中的前兩個元素均爲 2。

你不需要考慮數組中超出新長度後面的元素。

/**
 * @param {number[]} nums
 * @param {number} val
 * @return {number}
 */
var removeElement = function(nums, val) {
    var i = nums.length;
    while(i--){
        if (nums[i] == val){
           nums.splice(i,1);
        }
    }
    return nums.length;
};
//--i 是先執行i=i-1,然後再使用i的值, 這時的i 值就是表達式--i的值。
//i-- 是先使用i的值作爲表達式i--的值,然後,執行i=i-1操作。

 

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