测试用例为1 2 3 4不知道哪里有问题
int firstMissingPositive(int* nums, int numsSize){
int i;
for(i=0;i<numsSize;i++){
if(nums[i]<0){
nums[i]=0;
}
}
for(i=0;i<numsSize;i++){
if( (abs(nums[i])<numsSize) && (abs(nums[i])>=1)) {
nums[nums[i]]=-nums[nums[i]];
}
}
for(i=1;i<numsSize;i++){
if(nums[i]>0){
return nums[2];
}
}
return i+1;
}
我看到一个词汇heap-buffer-overflow也就是堆缓冲区溢出
它是在访问堆上分配的数组外部时发生的(比如使用malloc()分配的数组)
可能是数组开的太小了,导致溢出了。
如有帮助,还请帮忙点下采纳!感谢!