模拟qsort()函數,實作任意類型排序:
qsort()簡介:
原型:
void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 )
base:要排序的的數組的首位址
num:要排序的元素的個數
width:元素所占的位元組數
compare:函數指針,指向排序方式這個函數的指針。其中比較方式這個函數需要使用者根據自己的需要
使用qsort要調用<stdlib.h>。
#include<stdio.h>
#include<stdlib.h>
int compare(const void *elem1, const void *elem2) //比較方式
{
const int *str1 = (const int *)elem1;
const int *str2 = (const int *)elem2;
return *str1>*str2; //">"升序,“<"降序
}
void sort(void *base, size_t num,size_t byte, int(*cmp)(const void *elem1, const *elem2))
{
char *str = (char *)base;
int flag = 0;
const void *p1;
const void *p2;
for (size_t i = 0; i < num - 1; i++)
{
flag = 0;
for (size_t j = 0; j < num - 1 - i; j++)
{
p1 =(const void *)(str+(j*byte));
p2 = (const void *)(str+(j + 1)*byte);
if (cmp(p1,p2))
{
for (size_t k = 0; k < byte; k++) //按位元組交換
{
str[j*byte + k] = str[j*byte + k] + str[(j + 1)*byte + k];
str[(j+1)*byte + k] = str[j*byte + k] - str[(j + 1)*byte + k];
str[j*byte + k] = str[j*byte + k]-str[(j + 1)*byte + k];
}
flag = 1;
}
}
if (!flag)
break;
}
}
int main()
{
int(*cmp)(const void *elem1, const *elem2)=compare;
int arr[4] = { 20,40,5, 4 };
sort(arr,4,4, cmp);
for (int i = 0; i < 4; i++)
{
printf("%d ", arr[i]);
}
printf("\n");
system("pause");
return 0;
}