int minnum(int a, int b) {
if (a > b)
return b;
else
return a;
}
int* intersect(int* nums1, int nums1Size, int* nums2, int nums2Size, int* returnSize) {
int nums1_haxi[1001] = { 0 };
int nums2_haxi[1001] = { 0 };
int flag = 1;
int *p=NULL,j=0;
int tmp;
for (int i1 = 0; i1 < nums1Size; i1++) {
nums1_haxi[nums1[i1]]++;
}
for (int i2 = 0; i2 < nums2Size; i2++) {
nums2_haxi[nums2[i2]]++;
}
for (int i = 0; i < 1001; i++) {
if ((nums1_haxi[i] > 0 && nums2_haxi[i] > 0)) {
if (flag) {
p = malloc(sizeof(int));
tmp= i;
p[j] = tmp;
j++;
for (int k = 1; k < minnum(nums1_haxi[i], nums2_haxi[i]); k++) {
if(p!=NULL)
realloc(p, sizeof(int) * (j + 1));
tmp = i;
p[j] = tmp;
j++;
}
flag = 0;
}
else {
for (int k = 0; k < minnum(nums1_haxi[i], nums2_haxi[i]); k++) {
if(p!=NULL)
realloc(p, sizeof(int) * (j + 1));
tmp=i;
p[j] = tmp;
j++;
}
}
}
}
*returnSize = j;
return p;
}
执行出错,但是编译器上可以正常执行
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- 元气少女缘结神 2023-03-27 13:49关注
如果p指向的内存后没有足够的连续空间时,realloc就会将原有p指向的内存数据从头到尾拷贝到新分配的内存区域,而后释放原来p所指内存区域,而返回一个新地址。
所以你上面不用新地址接受realloc而直接用原p,可能面临原来的p已经被释放掉的风险,后面的访问就会越界报错。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 2024-五一综合模拟赛
- ¥15 下图接收小电路,谁知道原理
- ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
- ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
- ¥15 手机接入宽带网线,如何释放宽带全部速度
- ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
- ¥15 ETLCloud 处理json多层级问题
- ¥15 matlab中使用gurobi时报错
- ¥15 这个主板怎么能扩出一两个sata口
- ¥15 不是,这到底错哪儿了😭