0

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

我想到的是使用 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);

完整的代码正在建设中,请告诉我是否可以在我的方法中进行一些优化,或者为这个问题提供一些更好的替代方案。在我看来,它的尺寸真的会很大

很多很多提前谢谢

4

3 回答 3

2

由于该函数可能会使用您的交换例程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 的漂亮比较实现。)

对于一个数组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);
于 2012-07-07T05:11:23.443 回答
1

问题是这不允许对自定义类型(如结构)进行排序。通常的方法是接受一个函数指针,您调用它来进行比较。

于 2012-07-07T04:57:08.533 回答
1

您应该做的是将比较作为函数指针传递。您正在传递一个函数指针,但您似乎没有使用它来比较值。您不必预先定义所有比较,因为您可以在使用它们时为您使用的值类型定义它们。

于 2012-07-07T05:05:27.060 回答