问题
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
例子
思路
-
方法1
-
方法2
每个元素最多出现两次意味着:nums[i]!=nums[i-2]
代码
//方法1 我的
class Solution {
public int removeDuplicates(int[] nums) {
if(nums==null || nums.length==0) return 0;
int i=0,c=1;
for(int j=1; j<nums.length; j++) {
if(nums[i]!=nums[j]) {
nums[++i]=nums[j];
c=1;
}else{
c++;
if(c<=2) nums[++i]=nums[j];
}
}
return i+1;
}
}
//方法2
if(nums.length<=2) return nums.length;
int i=1;
for(int j=2; j<nums.length; j++) {
//nums[i]!=nums[i-2] i-1==i+1-2
if(nums[j]!=nums[i-1]) nums[++i]=nums[j];
}
return i+1;