题目:
给定一个增序排列数组 nums ,你需要在 原地 删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
int i=0;
for(int n:nums){
if(i<2||n>nums[i-2]){
nums[i++]=n;
}
}
拓展:
此方法可是实现每个元素最多出现K次,则代码是:
int i=0;
for(int n:nums){
if(i<k||n>nums[i-k]){
nums[i++]=n;
}
}