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 制裁名单20240508芯片厂商
- ¥20 易康econgnition精度验证
- ¥15 线程问题判断多次进入
- ¥15 msix packaging tool打包问题
- ¥28 微信小程序开发页面布局没问题,真机调试的时候页面布局就乱了
- ¥15 python的qt5界面
- ¥15 无线电能传输系统MATLAB仿真问题
- ¥50 如何用脚本实现输入法的热键设置
- ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
- ¥30 深度学习,前后端连接