题目来源于lettcode中的26题,以下为题目说明:
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
注意: 不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
代码实现如下:
int removeDuplicates(int* nums, int numsSize){
if (numsSize == 0)
return 0;
int i = 0;
int j = 1;
//遍历一遍数组
while (i<numsSize - 1)
{
//每次判断之前的都先会让重复出现的数字走到的最后一个
//走到最后一个时才会进入下边判断条件之中
//用j保存数组开始的下标
if (nums[i] != nums[i + 1])
{
nums[j]=nums[i+1];//直接在原数组上覆盖写
j++;
}
i++;
}
return j;
}

被折叠的 条评论
为什么被折叠?



