LeetCode数组题:删除有序数组中的重复元素并返回数组长度


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

img

求解答

当numsSize==0时,你需要返回值是0对吧
如果不加

if(numsSize==0)
        return 0;

当numsSize==0时,函数返回值是1

return p - nums + 1;

这可能就是报错的原因,有帮助请采纳

这句表明数组已处理完了,不能再继续了。
如果删除,再下面的p和q会超出数组范围,修改其它未知区域数据,造成程序崩溃。