gpt4 book ai didi

c - 在 C 中使用 void 指针对任何类型的元素进行排序

转载 作者:太空宇宙 更新时间:2023-11-04 06:38:49 25 4
gpt4 key购买 nike

大家好,我正在用 C 编写一个对一般元素进行排序的程序。它可以对任何类型的对象(整数、 float 、复数、对象)进行排序

我想到的是使用void指针,

void qsort(void *ptr,int sz,int i,int j,int (*fptr) (const void *,const void *) )
{

if(i<j)
{
int p=(i+j)/2;
p=partition(ptr,sz,i,j,p,fptr);
qsort(ptr,size,i,p-1,fptr);
qsort(ptr,size,p+1,j,fptr);
}
}

用于比较

通过sz的值我们可以知道它是否是一个指向string,int,char,float等的指针

int compare(const void* a,const void* b,int sz)
{
if(sz==0) //means pointer to a string
return strcmp( (char*)a, (char*)b );
else if(sz==1) //means int
return *(int*)a - *(int*)b;
else if(sz==2) //means float
return *(float*)a- *(float*)b;
else if(sz==3)
return *(char*)a- *(char*)b;
}

交换两个元素

void swap(void *a,void *b,int sz)//for swapping
{
if(sz==0)
{
void *c;
c=a;
a=b;
b=c;
}
else if(sz==1)
{
a=(int*)a;
b=(int*)b;
int c;
c= *a;
*a=*b;
*b=c;
}

else if(sz==2)
{
a=(float*)a;
b=(float*)b;
float c;
c= *a;
*a=*b;
*b=c;
}

已编辑

qsort(arr,4,0,9,&compare);

完整的代码正在构建中,请告诉我是否可以在我的方法中进行一些优化,或者针对此问题的一些更好的替代方案。在我看来,它的尺寸真的很大

提前很多很多谢谢

最佳答案

由于 partition 函数可能会使用您的交换例程,因此它应该适用于任意大小的对象,而不仅仅是您计划传递给代码的对象。

void swap (void *a, void *b, int sz) {
char buf[512];
void *p = buf;
if (sz > sizeof(buf)) p = malloc(sz);
memcpy(p, a, sz);
memcpy(a, b, sz);
memcpy(b, p, sz);
if (p != buf) free(p);
}

从您编写比较例程的方式来看,您似乎只打算发送某些类型的数组。但是,sz 通常用于说明数组中各个元素的大小,而不是作为类型标识符,因为您似乎正在尝试使用它。

struct x { int key; /*...*/ };

int cmp_x (const void *a, const void *b) {
const struct x *xa = a;
const struct x *xb = b;
return (xa->key > xb->key) - (xa->key < xb->key);
}

struct x array_x[100];
/* populate array */
qsort(array_x, sizeof(struct x), 0, 100, cmp_x);

这就是我想象的应该调用您的 qsort 的方式。 (感谢 Ambroz Bizjak 的漂亮 comparison implementation 。)

对于 int 数组:

int cmp_int (const void *a, const void *b) {
int ia = *(const int *)a;
int ib = *(const int *)b;
return (ia > ib) - (ia < ib);
}

int array_i[100];
/* populate array */
qsort(array_i, sizeof(int), 0, 100, cmp_int);

关于c - 在 C 中使用 void 指针对任何类型的元素进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11372342/

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