思路:我们可以采用两个标记点i和num,num来记录数组中不重复的元素。如果i位置的元素和num位置的元素不相等,需要放到num的下一位置。如果相等。则不用管,最后返回num+1。
代码:
int removeDuplicates(int* nums, int numsSize)
{ if(nums == NULL || numsSize == 0)
{
return 0;
}
int num = 0;
for(int i = 0;i< numsSize;i++)
{
if(nums[num] != nums[i])
num++;
nums[num] = nums[i];
}
return num+1;
}