80 删除排序数组中的重复项
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
- 双指针,一个指针遍历原数组,一个指针位于新数组末尾
class Solution {
public:
int removeDuplicates(vector<int>& nums) {
if(nums.size() <= 2){
return nums.size();
}
int pos = 2;
for(int i = 2;i < nums.size();i++){
if(nums[i] != nums[pos-2]){
nums[pos++] =nums[i];
}
}
return pos;
}
};
通过时间:

本文介绍了一种在原地删除排序数组中重复元素的方法,确保每个元素最多出现两次,并返回新数组的长度。该算法使用双指针技巧,一个遍历原数组,另一个指示新数组的末尾位置,实现O(1)空间复杂度。
104

被折叠的 条评论
为什么被折叠?



