模板 qsort和sort的詳解和比較函式的區別

2021-06-27 23:49:23 字數 3187 閱讀 7759

下面先對qsort和sort進行詳細的解釋,然後再將區別!(需要特別注意的就是qsort和sort的比較函式的寫法,很容易出錯)

first  qsort

基本快速排序的方法,每次把陣列分成兩分和中間的乙個劃分值,而對於有多個重複值的陣列來說,基本排序的效率較低。整合在c語言庫函式裡面的的qsort函式,使用三路劃分的方法解決這個問題。所謂三路劃分,是指把陣列劃分成小於劃分值,等於劃分值和大於劃分值的三個部分。

函式對buf 指向的資料按公升序排序。

使用方法:

void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )

int compare (const void *elem1, const void *elem2 ) );

qsort(quicksort)主要根據你給的比較條件給乙個快速排序,主要是通過指標移動實現排序功能。排序之後的結果仍然放在原來陣列中。

引數意義如下:

base:需要排序的目標陣列開始位址

num:目標陣列元素個數

width:目標陣列中每乙個元素長度

compare:函式指標,指向比較函式

一、對int型別陣列排序

int num[100];

int cmp ( const void *a , const void *b )

可見:引數列表是兩個空指標,現在他要去指向你的陣列元素。所以轉型為你當前的型別,然後取值。公升序排列。

因為是按照acs碼的值進行的,所以在前面的字元的值一定小於後面的字元。

那麼,對於a b,如果a的值》b的值,就說明在字母表中a在b的後面,返回值為1表示ture,執行交換。

qsort(num,100,sizeof(num[0]),cmp);

二、對char型別陣列排序(同int型別)

char word[100];

int cmp( const void *a , const void *b )

qsort(word,100,sizeof(word[0]),cmp);

三、對double型別陣列排序(特別要注意)

double in[100];

int cmp( const void *a , const void *b )

qsort(in,100,sizeof(in[0]),cmp);

四、對結構體一級排序

struct in

s[100]

//按照data的值從小到大將結構體排序,關於結構體內的排序關鍵資料data的型別可以很多種,參考上面的例子寫

int cmp( const void *a ,const void *b)

qsort(s,100,sizeof(s[0]),cmp);

五、對結構體二級排序

struct in

s[100];

//按照x從小到大排序,當x相等時按照y從大到小排序

int cmp( const void *a , const void *b )

qsort(s,100,sizeof(s[0]),cmp);

六、對字串進行排序

char str[100][100];

int cmp(const void* a,const void* b )

qsort(str,n,sizeof(str[0]),cmp);

值得注意的是,上面的n,很有可能你會誤認為是100,這裡實際應該是你要排序的個數,比如說你實際上只有str[0],str[1],str[2]這三個字串要排序,那麼n就應該是3,而不是100;

struct in

s[100];

//按照結構體中字串str的字典順序排序

int cmp ( const void *a , const void *b )

qsort(s,100,sizeof(s[0]),cmp);

注意!qsort 中的  cmp 得自己寫 。

second sort

sort 使用時得註明:using namespace std;   或直接打 std::sort()  還得加上  #include

例:#include

#include

using namespace std;

int main()

std::sort是乙個改進版的qsort. std::sort函式優於qsort的一些特點:對大陣列採取9項取樣,更完全的三路劃分演算法,更細緻的對不同陣列大小採用不同方法排序。

third  區別: 

sort是qsort的公升級版,如果能用sort盡量用sort,使用也比較簡單,不像qsort還得自己去寫 cmp 函式,只要註明  使用的庫函式就可以使用,引數只有兩個(如果是普通用法)頭指標和尾指標;

預設sort排序後是公升序,如果想讓他降序排列,可以使用自己編的cmp函式

bool compare(int a,int b)

sort(*a,*b,cmp);

sort和qsort的比較函式的主要區別:

例如要對乙個陣列進行排序:

#include #include using namespace std;

//下面的比較函式的返回值為0或者1

bool cmp1(int m, int n)

bool c***(int m, int n)

int cmp2(const void *a, const void *b)

int main()

; sort(a, a+10, cmp1);

//sort(a, a+10, c***);

//qsort(a, 10, sizeof(int), cmp2);

for (int i = 0; i < 10; i++)

cout << a[i] << " ";

cout << endl;

system("pause");

}可以看出上面的結果是出乎意料的!為什麼sort中的比較函式改為這樣就會出錯呢?!

是因為:在cmp1的比較函式中,其返回值為0和1,而在cmp2的比較函式中,其返回值為0,-1和1!

再看看下面的例子:

#include using namespace std;

bool solve(int a, int b)

int main()

如果還有什麼不明白的:再看看

qsort和sort的區別

first qsort 基本快速排序的方法,每次把陣列分成兩分和中間的乙個劃分值,而對於有多個重複值的陣列來說,基本排序的效率較低。整合在 c語言庫函式裡面的的 qsort 函式,使用 三路劃分的方法解決這個問題。所謂三路劃分,是指把陣列劃分成小於劃分值,等於劃分值和大於劃分值的三個部分。函式對bu...

sort和qsort的區別

std sort使用的演算法在大多數情況下都比quick sort演算法要快,並且,在quick sort越慢的情況下越明顯。quick sort 平均情況下為o nlogn 在最壞情況下為 o n 2 而std sort是針對quick sort最壞情況做的改進,從而保持了 o nlogn 的複雜...

sort和qsort的用法

好吧,承認知識匱乏,一直都是手打快排的,才知道有這個函式 必須要科普一下。msdn中的定義 template voidsort ranit first,ranit last 1 template voidsort ranit first,ranit last,pred pr 2 標頭檔案 inclu...