gpt4 book ai didi

c - 在c中的结构指针数组上使用qsort时比较整数的函数

转载 作者:行者123 更新时间:2023-11-30 15:59:34 26 4
gpt4 key购买 nike

stackoverflow 上有很多关于如何对结构指针数组进行排序的问题。我把它们都翻遍了,没有结果。我想对指向结构数组的指针数组进行排序。我首先为指针数组分配存储空间,然后为结构本身分配存储空间。一切看起来都很好,但我无法将它们排序。我确信问题出在比较函数中。我从 stackoverflow 复制了其中一些,它们列在下面。但它们都不起作用......

typedef struct s_stream{
int amc;
char *name;
} dataStream;

void abc(void)
{
int count = 100;

dataStream *_UniqueStreamBuild = calloc(count, sizeof(dataStream ));
dataStream **UniqueStreamBuild = calloc(count, sizeof(dataStream *));
for ( int i = 0; i < count; ++i) UniqueStreamBuild[i] = _UniqueStreamBuild + i;

//**Edit: ******** **
// here I call a cascade of functions that assign values to amc; those
// functions are correct: they produce an unsorted array of amc values;
// the output I am getting is an array of structures seemingly in random order.

qsort(UniqueStreamBuild, count, sizeof(dataStream *), compare);
}

int compare (const void * a, const void * b)
{
const dataStream *x = a;
const dataStream *y = b;

if (x->amc > x->amc)
return(1);

if (x->amc < x->amc)
return(-1);

return(0);
}


int compare( const void *a, const void *b )
{
dataStream *m1 = *(dataStream **)a;
dataStream *m2 = *(dataStream **)b;

if (m1->amc > m2->amc)
return(1);

if (m1->amc < m2->amc)
return(-1);

return(0);
}

最佳答案

你的第二个可能的 compare() 函数应该可以工作,除非它和下面的这个版本之间有一些我没有注意到的差异。对指针数组进行排序时,比较函数会向 dataStream * 传递两个指针,因此比较器应该与此非常相似:

int compare (const void *a, const void *b)
{
const dataStream *x = *(const dataStream **)a;
const dataStream *y = *(const dataStream **)b;

if (x->amc > y->amc)
return(1);
else if (x->amc < y->amc)
return(-1);
else
return(0);
}

此外,正如最初所写,您的函数之一始终返回 0,因为 x->amc == x->amc (您取消引用 x 两次,而不是 xy)。

您的测试代码没有完全初始化数据结构 - 它使用calloc(),因此结构中的字符串和指针都归零,因此排序作用不大。

<小时/>

这段代码适合我...你呢?

#include <stdio.h>
#include <stdlib.h>

typedef struct s_stream
{
int amc;
char *name;
} dataStream;

static int compare(const void *a, const void *b)
{
const dataStream *x = *(const dataStream **)a;
const dataStream *y = *(const dataStream **)b;

if (x->amc > y->amc)
return(1);
else if (x->amc < y->amc)
return(-1);
else
return(0);
}

static void dump(FILE *fp, const char *tag, dataStream * const * const data, int num)
{
const char *pad = "";
fprintf(fp, "Stream Dump (%s): (%d items)\n", tag, num);
for (int i = 0; i < num; i++)
{
fprintf(fp, "%s%d", pad, data[i]->amc);
if (i % 10 == 9)
{
putc('\n', fp);
pad = "";
}
else
pad = ", ";
}
putc('\n', fp);
}

static void abc(void)
{
int count = 100;

dataStream *_UniqueStreamBuild = calloc(count, sizeof(dataStream ));
dataStream **UniqueStreamBuild = calloc(count, sizeof(dataStream *));
for ( int i = 0; i < count; ++i)
{
UniqueStreamBuild[i] = _UniqueStreamBuild + i;
UniqueStreamBuild[i]->amc = (7 * i + 3) % count + 1;
}

dump(stdout, "Before", UniqueStreamBuild, count);
qsort(UniqueStreamBuild, count, sizeof(dataStream *), compare);
dump(stdout, "After", UniqueStreamBuild, count);

free(_UniqueStreamBuild);
free(UniqueStreamBuild);
}

int main(void)
{
abc();
return 0;
}

关于c - 在c中的结构指针数组上使用qsort时比较整数的函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8783042/

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