给你一个数组
nums和一个值val,你需要 原地 移除所有数值等于val的元素。元素的顺序可能发生改变。然后返回nums中与val不同的元素的数量。假设
nums中不等于val的元素数量为k,要通过此题,您需要执行以下操作:
- 更改
nums数组,使nums的前k个元素包含不等于val的元素。nums的其余元素和nums的大小并不重要。- 返回
k。
因为题目要求原地移除,不能复制数组,所以只能使用双指针。
python
class Solution:
def removeElement(self, nums: List[int], val: int) -> int:
if not nums:
return 0
slow = 0
for fast in range(len(nums)):
if nums[fast] != val:
nums[slow], nums[fast] = nums[fast], nums[slow]
slow += 1
return slow