gpt4 book ai didi

比较函数在 qsort 中给出段错误

转载 作者:行者123 更新时间:2023-11-30 14:39:58 24 4
gpt4 key购买 nike

我为 qsort 做了一个比较函数,它导致了段错误。为什么会发生这种情况以及如何解决?

example my two arrays are:
G->grades = [2,3,3,2,2,2]
G->order = [0,2,3,4,5,6]

我想使用 G->grades 值对 G->order 进行排序。所以输出应该是:
G->阶数 = [2,3,0,4,5,6]

u32* vert_grades;

char OrdenWelshPowell(Grafostv* G)
{
vert_grades = G->grades;
qsort(G->order, G->n, sizeof(u32), comp_grades);
return 0;
}

int comp_grades(const void *v1, const void *v2) {
u32 degree1 = vert_grades[*(const u32 *)v1 - 1];
u32 degree2 = vert_grades[*(const u32 *)v2 - 1];
printf("degree2: %u\n", vert_grades[*(const u32 *)v2 - 1]);
if (degree1 > degree2)
{
return -1;
}
else if (degree1 < degree2)
{
return 1;
}
else
{
return 0;
}
}

pd:我暂时不想订购 G-> 成绩。

最佳答案

你有数组

G->order = [0,2,3,4,5,6]

请注意,您的数组有 6 个元素,因此它们的索引范围必须为 0..51..6。您的 cmp 函数假定为后者,因为它从索引中减去 1

但是排序数组的范围0..6 不适合这两个系统。在这种情况下,第一个值 0 将打破数组边界,因为您减去了 1

我建议排序前的初始数据应该是

G->order = [1,2,3,4,5,6]

关于比较函数在 qsort 中给出段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55797386/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com