int removeDuplicates(int* nums, int numsSize)
{
int* p = nums, * q = nums + 1;
if (numsSize == 0)
return 0;
while (q - nums < numsSize) {
if (*p == *q);
else
*++p = *q;
q++;
}
return p - nums + 1;
}
这么写通过了,一开始的时候没有加
if(numsSize==0)
return 0;
没有加这句话时,就会导致不通过,系统报错heap-buffer-overflow
求解答
当numsSize==0时,你需要返回值是0对吧
如果不加
if(numsSize==0)
return 0;
当numsSize==0时,函数返回值是1
return p - nums + 1;
这可能就是报错的原因,有帮助请采纳
这句表明数组已处理完了,不能再继续了。
如果删除,再下面的p和q会超出数组范围,修改其它未知区域数据,造成程序崩溃。