这包炫赫门不太甜
2021-09-06 13:42
采纳率: 50%
浏览 32

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

求解答

  • 收藏

2条回答 默认 最新

  • 信仰869 2021-09-06 14:36
    已采纳

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

    if(numsSize==0)
            return 0;
    

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

    return p - nums + 1;
    

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

    打赏 评论
  • baidu_30233079 2021-09-06 14:21

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

    打赏 评论

相关推荐 更多相似问题