LeetCode-Array-移除元素(Java)

題目描述:

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

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

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

示例 1:

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

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

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

方法:

雙指針法:
  • 因爲題目需要再原地址上直接覆蓋新的數據,則可以和第26題一樣採用快慢指針法,只是這裏快指針要從j=1開始,因爲可能第一個元素就等於val。
  • 通過快指針遍歷整個數組,如果nums[ j ]!=val,先把nums[ i ]=nums[ j ],然後再將i++;
  • 時間複雜度爲O(n);
詳細代碼:
class Solution {
    public int removeElement(int[] nums, int val) {
        int i =0;
        for(int j =0;j<nums.length;j++){
            if(nums[j]!=val){
                nums[i] =nums[j];
                i++;
            }
        }
        return i;
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章