qsort是編譯器函數(shù)庫自帶的快速排序函數(shù)。其原型為:
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:國際域名空間、雅安服務(wù)器托管、營銷軟件、網(wǎng)站建設(shè)、張灣網(wǎng)站維護、網(wǎng)站推廣。
void qsort(void*base,size_t num,size_t width,int(__cdecl*compare)(const void*,const void*));
參數(shù)含義如下:
base: 待排序數(shù)組首地址。
num: 數(shù)組中待排序元素數(shù)量。
width: 各元素的占用空間大小。
compare: 指向函數(shù)的指針,用于確定排序的順序。
比較難以理解的是compare函數(shù)指針,其確定了如何去排序,通過修改該函數(shù)指針指向的函數(shù)體,可以對復(fù)雜類型進行排序,如結(jié)構(gòu)體等。 也可以改變排序方式,如升序或降序。
要達到問題中的效果,需要在第一個參數(shù)傳入數(shù)據(jù)所在行的首地址,第二個參數(shù)傳入一行中元素的個數(shù),第三行傳入每個元素占用的空間,第四個傳入自定義的比較函數(shù)指針(函數(shù)名)。
下面就以一個3行4列整型數(shù)組a[3][4],對其第二行(a[1])進行升序排序為例,寫一個代碼,輔助理解。
#include?stdio.h
#include?stdlib.h
int?cmp(const?void?*a,?const?void?*b)
{
return?*((int?*)a)??*((int?*)b);//由于是整型數(shù)組,所以將指針轉(zhuǎn)為整型指針后取值,再比較。
}
int?main()
{
int?a[3][4]?=?
{
5,1,54,6,
22,12,44,32,
34,5,2,1
};//定義的原始數(shù)組,可以看到是亂序的。
int?i,j;
qsort(a[1],?4,?sizeof(int),?cmp);
//以下代碼輸出數(shù)組元素值,以驗證排序結(jié)果。
for(i?=?0;?i??3;?i?++)
{
for(j?=?0;?j??4;?j?++)
printf("%3d",a[i][j]);
printf("\n");
}
return?0;
}
程序運行后輸出:
5??1?54??6
12?22?32?44
34??5??2??1
可以看到第二行已經(jīng)升序排列,而其它兩個沒有變化。
C語言中沒有預(yù)置的sort函數(shù)。如果在C語言中,遇到有調(diào)用sort函數(shù),就是自定義的一個函數(shù),功能一般用于排序。
一、可以編寫自己的sort函數(shù)。
如下函數(shù)為將整型數(shù)組從小到大排序。
void?sort(int?*a,?int?l)//a為數(shù)組地址,l為數(shù)組長度。
{
int?i,?j;
int?v;
//排序主體
for(i?=?0;?i??l?-?1;?i?++)
for(j?=?i+1;?j??l;?j?++)
{
if(a[i]??a[j])//如前面的比后面的大,則交換。
{
v?=?a[i];
a[i]?=?a[j];
a[j]?=?v;
}
}}
對于這樣的自定義sort函數(shù),可以按照定義的規(guī)范來調(diào)用。
二、C語言有自有的qsort函數(shù)。
功 能: 使用快速排序例程進行排序
頭文件:stdlib.h
原型: void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));
參數(shù):
1 待排序數(shù)組首地址
2 數(shù)組中待排序元素數(shù)量
3 各元素的占用空間大小
4 指向函數(shù)的指針,用于確定排序的順序
這個函數(shù)必須要自己寫比較函數(shù),即使要排序的元素是int,float一類的C語言基礎(chǔ)類型。
以下是qsort的一個例子:
#includestdio.h
#includestdlib.h
int?comp(const?void*a,const?void*b)//用來做比較的函數(shù)。
{
return?*(int*)a-*(int*)b;
}
int?main()
{
int?a[10]?=?{2,4,1,5,5,3,7,4,1,5};//亂序的數(shù)組。
int?i;
qsort(a,n,sizeof(int),comp);//調(diào)用qsort排序
for(i=0;i10;i++)//輸出排序后的數(shù)組
{
printf("%d\t",array[i]);
}
return?0;
}
擴展資料:
sort函數(shù)的用法(C++排序庫函數(shù)的調(diào)用)
對數(shù)組進行排序,在c++中有庫函數(shù)幫我們實現(xiàn),這們就不需要我們自己來編程進行排序了。
(一)為什么要用c++標準庫里的排序函數(shù)
Sort()函數(shù)是c++一種排序方法之一,學(xué)會了這種方法也打消我學(xué)習c++以來使用的冒泡排序和選擇排序所帶來的執(zhí)行效率不高的問題!因為它使用的排序方法是類似于快排的方法,時間復(fù)雜度為n*log2(n),執(zhí)行效率較高!
(二)c++標準庫里的排序函數(shù)的使用方法
I)Sort函數(shù)包含在頭文件為#includealgorithm的c++標準庫中,調(diào)用標準庫里的排序方法可以不必知道其內(nèi)部是如何實現(xiàn)的,只要出現(xiàn)我們想要的結(jié)果即可!
II)Sort函數(shù)有三個參數(shù):
(1)第一個是要排序的數(shù)組的起始地址。
(2)第二個是結(jié)束的地址(最后一位要排序的地址的下一地址)
(3)第三個參數(shù)是排序的方法,可以是從大到小也可是從小到大,還可以不寫第三個參數(shù),此時默認的排序方法是從小到大排序。
Sort函數(shù)使用模板:
Sort(start,end,排序方法)
下面就具體使用sort()函數(shù)結(jié)合對數(shù)組里的十個數(shù)進行排序做一個說明!
例一:sort函數(shù)沒有第三個參數(shù),實現(xiàn)的是從小到大
#includeiostream
#includealgorithm
using namespace std;
int main()
{
int a[10]={9,6,3,8,5,2,7,4,1,0};
for(int i=0;i10;i++)
couta[i]endl;
sort(a,a+11);
for(int i=0;i10;i++)
couta[i]endl;
return 0;
}
編譯器
GCC,GNU組織開發(fā)的開源免費的編譯器
MinGW,Windows操作系統(tǒng)下的GCC
Clang,開源的BSD協(xié)議的基于LLVM的編譯器
Visual C++?:: cl.exe,Microsoft VC++自帶的編譯器
集成開發(fā)環(huán)境
CodeBlocks,開源免費的C/C++ IDE
CodeLite,開源、跨平臺的C/C++集成開發(fā)環(huán)境
Orwell Dev-C++,可移植的C/C++IDE
C-Free
Light Table
Visual Studio系列
Hello World
參考資料:百度百科-sort函數(shù)
排序方法有很多種, 選擇排序,冒泡排序,歸并排序,快速排序等。
看名字都知道快速排序 是目前公認的一種比較好的排序算法(我沒聽書速度比這快的了,特殊場合例外),比選擇排序,冒泡排序都要快。這是因為他速度很快,所以系統(tǒng)也在庫里實現(xiàn)這個算法,便于我們的使用。
這就是qsort。
qsort 要求提供一個 比較函數(shù),是為了做到通用性更好一點。比如你不僅僅的是要排序一個數(shù)字而已,可能你要用來排序幾個數(shù)字 ,比如有一個結(jié)構(gòu)
struct num {
int a;
int b;
};
然后我有一個num 類型的數(shù)組, num dddd[100];
我想給 dddd這個數(shù)組排序,那怎么辦? 我想讓 a +b 最大的num元素排在數(shù)組的最前面,那又怎么辦?
這都可以通過定義比較函數(shù)來做到的。
比較函數(shù)的作用就是給qsort指明 元素的大小是怎么比較的。
像這樣的比較函數(shù) inline int MyCmp(const void* a, const void* b)
都是有兩個元素 作為參數(shù),返回一個int 值, 如果 比較函數(shù)返回大于0,qsort就認為 ab , 如果比較函數(shù)返回等于0 qsort就認為a 和b 這兩個元素相等,返回小于零 qsort就認為 ab 。
qsort 知道元素大小,就可以把大的放到前面去。
如果你的比較函數(shù)放回本來應(yīng)該是1 的(ab),你比較函數(shù)卻返回一個 -1 (小于零的)那么qsort認為ab 的,就把 b放到前面去,但實際上是a大于b的,所以就造成升降序的差別了。
同樣的道理,如果有一個 結(jié)構(gòu)
strunt 人{
int 身高;
int 體重;
}
你想讓身高最小的人排在最前面,那么你也要自己定義自己的比較函數(shù) ,