みなさん、こんにちは。Cで一般的な要素を並べ替えるプログラムを書いています。あらゆる種類のオブジェクト(int、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;
}
2つの要素を交換するため
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);
完全なコードは作成中です。私のアプローチにいくつかの最適化があるかどうか、またはこの問題のいくつかのより良い代替案があるかどうか教えてください。本当に大きくなると思いますが
多くの人が事前に感謝します