函數(shù)原型:
void qsort(void *base,size_t num,size_t width,
int (__cdecl *compare )(const void *, const void *) );
第一個(gè)是數(shù)組地址,第二是數(shù)組大小,第三個(gè)是數(shù)組中每個(gè)元素的字節(jié)數(shù),最后一個(gè)是個(gè)函數(shù)指針,表示如何比較數(shù)組中的元素。
頭文件 #include <stdlib.h>
下面分別就int等整數(shù)數(shù)據(jù),double等浮點(diǎn)數(shù)據(jù),結(jié)構(gòu)體和類,按指定方式這四種情況進(jìn)行講解。
實(shí)例1、對int等整數(shù)數(shù)據(jù)進(jìn)行排序
實(shí)例2、對double等浮點(diǎn)數(shù)進(jìn)行排序
bool flag1 = *pcx >= 'A' && *pcx <= 'Z';
bool flag2 = *pcy >= 'A' && *pcy <= 'Z';
if(flag1 == flag2) //如果都為大寫字母或都為小寫字母
return *pcx - *pcy;
else //否則,誰為大寫字母,誰的權(quán)值小。
return flag1 ? -1 : 1;
}
int main()
{
char szText[] = "AajkuKdYUBCDwyz";
qsort(szText, strlen(szText), sizeof(szText[0]), cmp1);
printf("%s/n", szText);
return 0;
}
新聞熱點(diǎn)
疑難解答
圖片精選