3 回答

TA貢獻1851條經驗 獲得超5個贊
當您刪除前 3 個時,您將擁有 i=0,接下來數組列表將調整大小,因此當您刪除時,您需要執行 i - -。
class Solution {
public int removeElement(int[] nums, int val) {
ArrayList<Integer> list = new ArrayList<Integer>();
for(int i = 0; i < nums.length; i++) {
list.add(nums[i]);
}
if(list.isEmpty()) {
return 0;
}
for(int i = 0; i < list.size(); i++) {
if(list.get(i) == val) {
list.remove(i);
i--;
}
}
return list.size();
}
}

TA貢獻1812條經驗 獲得超5個贊
您根本不需要調用 remove(像您一樣刪除時,沒關系,但是例如,如果您在 foreach 循環中執行此操作,它會在 . 上崩潰ConcurrentModificationException。相反,您可以確定是否將 item 添加到結果中列出或不在第一個for循環內(我認為這更安全):
ArrayList<Integer> list = new ArrayList<Integer>();
for(int i = 0; i < nums.length; i++) {
if (nums[i] != val) {
list.add(nums[i]);
}
}
return list.size();
(我知道這不能直接回答你的問題)

TA貢獻1804條經驗 獲得超7個贊
您沒有顯示任何打印代碼,但我假設您nums
根據此方法返回的數字進行打印。這意味著您永遠不會nums
以任何方式進行更改,只需從那里打印前 n 個數字。您需要返回修改后的數組,而不僅僅是長度。
添加回答
舉報