題目描述:
給定一個數組 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;
}
}