C語言庫函數(shù)中qsort()的用法
qsort是庫函數(shù)提供的一種排序方法,我們就簡單1了解一下怎么去用,而不去深究它的庫函數(shù)是怎么寫的
qsort是庫函數(shù)中提供的一種能排序任何類型的數(shù)據(jù)的一種排序方法,思想是quick sort(快速排序),今天我聽鵬哥講指針,剛好引入了這一點,我就趁熱打鐵,總結(jié)一下該排序的用法
(一)void*? 的指針類型是什么?
void*類型的指針是能接受任何數(shù)據(jù)類型的地址,但是void*的指針類型是不能進行解引用操作的,也不能進行加減整數(shù)的操作,因為void*不知道它會占用多少個字節(jié)
#include <stdio.h> int main() { int a=10; char ch='w'; void* p=&a; p=&ch; return 0; }
(二)void?qsort(void*,?size_t,?size_t,?int?(?*?)(const?void?*?,??const?void?*??))? 該怎么使用該庫函數(shù)?
我們先來看看qsort()內(nèi)部有些什么參數(shù),參數(shù)類型是什么,該怎么用。
void?qsort(void* base,?size_t,?size_t,?int?(?*?)(const?void?*?,??const?void?*??))
可以看出共有四個參數(shù)
1.void1* base:待排序數(shù)組的首地址,可直接輸入待排序數(shù)組名,也可使用指針指向該數(shù)組
2.size_t num:數(shù)組的長度,假如有數(shù)組int arr[ ]用sz=sizeof(arr)/sizeof(arr[0])來計算數(shù)組的長度
3.size_t width:數(shù)組中的元素所占字節(jié),可用sizeof(arr[0])來計算單個元素的字節(jié)數(shù)
4.
int (*cmp)(const void* e1,const void* e2) { return *(int*)e1 - *(int*)e2;//因為void*類型的指針不能進行加減操作,所以先將e1,e2進行強制類型轉(zhuǎn)換,轉(zhuǎn)為int*,然后對其進行解引用 //不同的情形可以根據(jù)不同的比較方式來寫入這個函數(shù) //例如,字符串進行比較的時候,可以引用strcmp()這個函數(shù) }
:從這個形式可看出這是一個函數(shù)指針類型的參數(shù),意味著將要調(diào)用一個函數(shù),而這個函數(shù)在庫函數(shù)中表示進行排序的方式
這里簡單解釋一下這個函數(shù)指針的意義
int 表示返回的是一個int類型的值
cmp表示函數(shù)名,*cmp表示指向這個函數(shù)
(const void* e1,const void* e2)這里·的e1,e2表示將要進行比較的兩個元素,然后將兩個元素的地址傳到函數(shù)里,const表示無法修改指針指向的值
(三)使用qsort()來排序不同類型的數(shù)據(jù)
1.整型
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> int cmp_int(const void* e1, const void* e2) { return *(int*)e1 - *(int*)e2; } int main() { int arr[10] = { 3,4,1,2,7,8,9,5,6,0 }; int sz = sizeof(arr) / sizeof(arr[0]); qsort(arr, sz, sizeof(arr[0]), cmp_int); int i = 0; for (i = 0; i < sz; i++) { printf("%d ", arr[i]); } return 0; }
2.浮點型
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> int cmp_float(const void* e1, const void* e2) { return (int)(*(int*)e1 - *(int*)e2); } int main() { float arr[6] = { 2.0,2.3,4.5,5.0,8.0,9.0 }; int sz = sizeof(arr) / sizeof(arr[0]); qsort(arr, sz, sizeof(arr[0]), cmp_float); int i = 0; for (i = 0; i < sz; i++) { printf("%.2f ", arr[i]); } return 0; }
3.結(jié)構(gòu)體數(shù)據(jù)類型(數(shù)字,字符串)
下面我創(chuàng)建了一個機構(gòu)體,我先以結(jié)構(gòu)體中年齡排序
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> struct stu { char name[20]; int age; char sex[10]; }; int cmp_stu_by_age(const void* e1, const void* e2)//按年齡排序 { return ((struct stu*)e1)->age- ((struct stu*)e2)->age; } int main() { struct stu s[3] = { {"zhangsan",30,"man"},{"lisi",20,"man"},{"ruhua",18,"woman"}}; int sz = sizeof(s) / sizeof(s[0]); qsort(s, sz, sizeof(s[0]), cmp_stu_by_age); int i; for (i = 0; i < sz; i++) { printf("%s %d %s\n", s[i].name, s[i].age, s[i].sex); } return 0; }
?然后以姓名排序
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> #include <string.h> struct stu { char name[20]; int age; char sex[10]; }; int cmp_stu_by_name(const void* e1, const void* e2) { return strcmp(((struct stu*)e1)->name, ((struct stu*)e2)->name); } //int cmp_stu_by_age(const void* e1, const void* e2) //{ // return ((struct stu*)e1)->age- ((struct stu*)e2)->age; //} int main() { struct stu s[3] = { {"zhangsan",30,"man"},{"lisi",20,"man"},{"ruhua",18,"woman"}}; int sz = sizeof(s) / sizeof(s[0]); qsort(s, sz, sizeof(s[0]), cmp_stu_by_name); int i; for (i = 0; i < sz; i++) { printf("%s %d %s\n", s[i].name, s[i].age, s[i].sex); } return 0; }
?總結(jié):
今天的qsort就這樣了,關(guān)鍵在于
int cmp_int(const void* e1, const void* e2)
{
return *(int*)e1 - *(int*)e2;
}這一部分的書寫與理解,然后就是孰能生巧,多練習(xí)就會知道怎么用了
到此這篇關(guān)于C語言庫函數(shù)中qsort()的用法的文章就介紹到這了,更多相關(guān)C語言qsort()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實現(xiàn)LeetCode(199.二叉樹的右側(cè)視圖)
這篇文章主要介紹了C++實現(xiàn)LeetCode(199.二叉樹的右側(cè)視圖),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08C語言類型轉(zhuǎn)換與常量的細(xì)節(jié)深入理解探究
這篇文章主要為大家介紹了C?語言類型轉(zhuǎn)換與常量的細(xì)節(jié)深入理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12用C++實現(xiàn),將一句話里的單詞進行倒置的方法詳解
本篇文章是對用C++實現(xiàn),將一句話里的單詞進行倒置的方法進行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05