删除重复元素2--Java
在这个题目中,依然用的是双指针来进行对数组的删除(移位)操作,只不过,跟上一题有些不同,这里当两个指针不同和两个指针相同,并且距离小于2时,都要进行删除(移位)操作。
class Solution {
public int removeDuplicates(int[] nums) {
if(nums.length==0)return 0;
int number=0;
int q=0;
for(int p=1;p<nums.length;p++){
if(nums[q]==nums[p]){//当两个指针指向相同时进行一次判定,number小于2,进行删除操作
number++;
if(number<2){
nums[++q]=nums[p];
}
}
if(nums[q]!=nums[p]){
nums[++q]=nums[p];
number=0;
}
}
return q+1;
}
}