快慢指针法,其实我之前的方法思路也是这样,不过我的处理方法不同,而且麻烦,我的处理方法是发现重复项后进行覆盖。而题解的方法是用指针j发现不重复的对i后面的一项进行覆盖。这就提示我有时要从反面思考。
代码附上:
int removeDuplicates(int* nums, int numsSize){
if(numsSize==0) return 0;
int i=0,j;
for(j=1;j<numsSize;j++)
{
if(nums[j]!=nums[i])
{
i++;
nums[i]=nums[j];
}
}
return i+1;
}
力扣:删除排序数组中的重复项
最新推荐文章于 2023-07-09 20:47:28 发布