目錄
創(chuàng)新互聯(lián)-云計算及IDC服務提供商,涵蓋公有云、IDC機房租用、服務器托管、等保安全、私有云建設等企業(yè)級互聯(lián)網(wǎng)基礎服務,服務電話:028-869222201. qsort()函數(shù)簡介
1.1 函數(shù)原型
1.2 函數(shù)參數(shù)?
2. 比較函數(shù)簡介
2. 1 比較函數(shù)參數(shù)?
2.2 比較函數(shù)使用?
3. qsort()函數(shù)使用?
3.1 整形數(shù)組排序
3.2 字符數(shù)組排序
3.3 浮點型數(shù)組排序(double類型為例)
3. 4 字符串數(shù)組排序?
3.5 結(jié)構(gòu)體?
1.1 函數(shù)原型qsort()函數(shù)是C語言庫函數(shù)中的一種排序函數(shù),排序方法為快速排序(quick sort)?。
其特點是可以排序任意類型的數(shù)組元素。
1.2 函數(shù)參數(shù)?void qsort(void* base, size_t num, size_t size, int (*comparator)(const void* elem1, const void* elem2));
需引用頭文件:
或
2. 比較函數(shù)簡介 2. 1 比較函數(shù)參數(shù)?qsort()函數(shù)需要四個參數(shù)
1. void* base:??需排序數(shù)組首元素
2. size_t num:?數(shù)組元素個數(shù)
3. size_t size:?一個數(shù)組元素大小(byte)
4. int (*comparator) (const void* elem1?, const void* elem2):? 是一個函數(shù)指針,其指向的是一個比較函數(shù)的地址,該函數(shù)有兩個void* 的參數(shù),其返回類型為int 。
void* 類型指針:可以接收任意類型的地址,但不能進行解引用操作和不能對其進行加減整數(shù)的操作。
2.2 比較函數(shù)使用?比較函數(shù)為自定義函數(shù):其兩個參數(shù)為void*類型指針的elem1和elem2 ,返回參數(shù)為整形int
參數(shù)類型為void*原因:不清楚需比較元素的類型是什么,所以通過void*類型指針的特點(可以接收任意類型的地址)來接收。const修飾其兩個比較參數(shù)不可被更改
返回值有三種情況:?
< 0 : elem1 小于 elem2
=?0 : elem1 等于 elem2
>0 : elem1 大于 elem2
3. qsort()函數(shù)使用? 3.1 整形數(shù)組排序如需使用比較函數(shù)而void*類型指針不能解引用操作和加減整數(shù)操作我們只需對兩個元素進行強制類型轉(zhuǎn)換為我們想比較元素的類型指針,再進行解引用獲取兩個元素的值,最后進行兩個元素的差值返回。
整型數(shù)組
int comp_int(const void* elem1, const void* elem2) { return *(int*)elem1 - *(int*)elem2; }
字符數(shù)組
int comp_char(const void* elem1, const void* elem2) { return *(char*)elem1 - *(char*)elem2;//字符計算是計算ASCLL值 }
浮點型數(shù)組
int comp_double(const void* elem1, const void* elem2) { return (int)(*(double*)elem1 - *(double*)elem2); //浮點型差值為浮點型,而返回值需要為int型,避免報錯將差值強制類型轉(zhuǎn)換為int型 }
字符串
按首字母排序
int comp_char(const void* elem1, const void* elem2) { return *(char*)elem1 - *(char*)elem2;//字符計算是計算ASCLL值 }
按字符串長度排序
int comp_string(const void* elem1, const void* elem2) { if (strlen(*(char*)elem1) >strlen(*(char*)elem2)) { return 1; } else if (strlen(*(char*)elem1)< strlen(*(char*)elem2)) { return -1; } else { return 0; } }
按正常排序
int comp_string(const void* elem1, const void* elem2) { return strcmp(*(char*)elem1, *(char*)elem2);//strcmp比較兩個字符串大小 }
結(jié)構(gòu)體
struct stu { char name[20]; int grade; };
對學生姓名排序
int comp_string(const void* elem1, const void* elem2) { return strcmp(((str*)elem1)->name, ((str*)elem2)->name); }
對學生成績排序
int comp_string(const void* elem1, const void* elem2) { return strcmp(((str*)elem1)->grade, ((str*)elem2)->grade); }
3.2 字符數(shù)組排序int cmp_int(const void* elem1, const void* elem2) { return *(int*)elem1 - *(int*)elem2; } int main() { int arr[] = { 2,4,6,8,10,1,3,5,9,7 }; int sz = sizeof(arr) / sizeof(arr[0]); int i = 0; qsort(arr, sz, sizeof(arr[0]), cmp_int); for (i = 0; i< sz; i++) { printf("%d ", arr[i]); } return 0; }
3.3 浮點型數(shù)組排序(double類型為例)int cmp_char(const void* elem1, const void* elem2) { return *(char*)elem1 - *(char*)elem2; } int main() { char ch[] = {'b','c','a','e','f','d','g'}; int sz = sizeof(ch) / sizeof(ch[0]); int i = 0; qsort(ch, sz, sizeof(ch[0]), cmp_char); for (i = 0; i< sz; i++) { printf("%c ", ch[i]); } return 0; }
3. 4 字符串數(shù)組排序?int cmp_double(const void* elem1, const void* elem2) { return (int)(*(double*)elem1 - *(double*)elem2); } int main() { double arr[] = {2.5,1.0,3.5,4.5,2.0}; int sz = sizeof(arr) / sizeof(arr[0]); int i = 0; qsort(arr, sz, sizeof(arr[0]), cmp_double); for (i = 0; i< sz; i++) { printf("%f ", arr[i]); } return 0; }
3.5 結(jié)構(gòu)體?按字符串首字母排序
int cmp_string(const void* elem1, const void* elem2) { return *(char*)elem1 - *(char*)elem2; } int main() { char ch[5][10] = { "black","cat","apple","face","dog" }; int sz = sizeof(ch) / sizeof(ch[0]); int i = 0; qsort(ch, sz, sizeof(ch[0]), cmp_string); for (i = 0; i< sz; i++) { printf("%s ", ch[i]); } return 0; }
按正常排序
int cmp_string(const void* elem1, const void* elem2) { return strcmp((char*)elem1,(char*)elem2); } int main() { char ch[5][10] = { "aaa","a","aaaaa","aa","aaaa" }; int sz = sizeof(ch) / sizeof(ch[0]); int i = 0; qsort(ch, sz, sizeof(ch[0]), cmp_string); for (i = 0; i< sz; i++) { printf("%s ", ch[i]); } return 0; }
typedef struct Stu { char name[20]; int age; }Stu; int cmp_str(const void* elem1, const void* elem2) { return strcmp(((Stu*)elem1)->name, ((Stu*)elem2)->name); } int main() { Stu s[] = { {"張三",18},{"李四",19},{"王五",20} }; int sz = sizeof(s) / sizeof(s[0]); int i = 0; qsort(s, sz, sizeof(s[0]), cmp_str); for (i = 0; i< sz; i++) { printf("%s %d\n", s[i].name, s[i].age); } return 0; }
你是否還在尋找穩(wěn)定的海外服務器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機房具備T級流量清洗系統(tǒng)配攻擊溯源,準確流量調(diào)度確保服務器高可用性,企業(yè)級服務器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧
本文標題:C語言庫函數(shù)—qsort()詳解-創(chuàng)新互聯(lián)
網(wǎng)頁地址:http://vcdvsql.cn/article0/gihoo.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、用戶體驗、軟件開發(fā)、網(wǎng)站設計公司、品牌網(wǎng)站設計、網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)