麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C > 正文

如何使用VC庫函數(shù)中的快速排序函數(shù)

2020-01-26 15:52:44
字體:
供稿:網(wǎng)友

函數(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)行排序

復(fù)制代碼 代碼如下:

int cmp(const void *x, const void *y)
{
 return *(int*)x - *(int*)y;
}
qsort(a, MAXN, sizeof(a[0]), cmp);

MAXN為數(shù)組大小,下同

實(shí)例2、對double等浮點(diǎn)數(shù)進(jìn)行排序

復(fù)制代碼 代碼如下:

int cmpDouble(const void *x, const void *y)
{
 return (*(double*)x > *(double*)y ? 1 : -1);
}
qsort(a, n, sizeof(a[0]), cmpDouble);

實(shí)例3、對結(jié)構(gòu)體,類等復(fù)雜數(shù)據(jù)進(jìn)行排序

復(fù)制代碼 代碼如下:

struct Student
{
 char szName[30];
 int  nAge;
};

先對年齡排序,年齡相同再按姓名排序。
復(fù)制代碼 代碼如下:

int cmpStudent (const void *x, const void *y)
{   //先作下指針轉(zhuǎn)換,再按要求比較
 Student *pNodex = (Student*)x, *pNodey = (Student*)y;
 if (pNodex->nAge != pNodey->nAge)
  return pNodex->nAge - pNodey->nAge;
 else
  return strcmp(pNodex->szName, pNodey->szName);
}
qsort(a, n, sizeof(a[0]), cmpStudent);

實(shí)例4、按指定方式進(jìn)行排序。
如對只有大小寫字母的字符串"AajkuKdYUBCDwyz"進(jìn)行排序,要求大寫字母在前,小寫字母在后。
復(fù)制代碼 代碼如下:

int cmp1(const void *x, const void *y)
{
 char *pcx = (char*)x, *pcy = (char*)y;

 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;
}

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 久久久久国产精品久久久久 | 国产精品久久久久久久亚洲按摩 | 亚洲一区 国产精品 | av在线看网站 | 视频一区免费观看 | 一级黄色毛片a | 亚欧在线免费观看 | 免费黄色在线观看网站 | 久久精品国产99久久6动漫亮点 | 亚洲人成在线播放 | 国产91免费看 | 欧美日韩经典在线 | 一级成人免费 | 丁香天堂网 | 视频一区 日韩 | www国产网站| 91一区二区三区久久久久国产乱 | 国产无区一区二区三麻豆 | 极品销魂一区二区三区 | 免费观看黄视频 | 一区二区三区在线观看国产 | 国产精品99久久久久久久女警 | 欧洲黄色一级视频 | 日本看片一区二区三区高清 | 国产免费一区二区三区在线能观看 | 日韩中文字幕一区二区三区 | 国内精品久久久久久久久久久久 | 国产九色视频在线观看 | 欧美18—19sex性hd | 欧美一级毛片一级毛片 | 欧美 videos粗暴 | 销魂美女一区二区 | 成人午夜在线免费观看 | 羞羞视频在线免费 | 97久久精品一区二区三区观看 | caoporn国产一区二区 | 成人国产精品色哟哟 | 一级在线视频 | 成人午夜精品久久久久久久3d | 日本高清视频网站www | 久久久久久久午夜 |