今天在力扣刷题碰到需要使用qsort函数,结果一个测试案例没过,报错如下
signed integer overflow: 0 - -2147483648 cannot be represented in type 'int
有符号整数溢出:0--2147483648不能在“int”类型中表示
报错是在cmp函数中,当时我就纳闷这不是还在范围内吗,思来想去发现了问题
这是我原来的cmp函数
int cmp(const void *a,const void *b){
return (*(const int*)a > *(const int*)b);
}
a此时已经是-2147483648,再减去b,只要b大于0,那就溢出了
解决办法:
把减号改成大于号即可
int cmp(const void *a,const void *b){
return (*(const int*)a > *(const int*)b);
}
这样就顺利通过了。
网上关于这个问题很少,可能是太白痴了,发个帖子帮助跟我一样的小白们
博客作者在LeetCode刷题时遇到使用qsort函数导致的有符号整数溢出错误。问题源于cmp函数中比较操作导致的数值溢出。原始cmp函数在a为最小整数值-2147483648时,若再进行减法操作,将引发溢出。解决方案是将cmp函数中的减法改为大于号,避免直接相减。这个简单的错误可能导致复杂的问题,作者分享经验以帮助初学者避免类似陷阱。

5201

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



