日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

快排模板

發(fā)布時間:2025/5/22 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 快排模板 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
快速排序-6類qsort排序

以下是其具體分類及用法(若無具體說明是以降序排列):

1、對一維數(shù)組排序:

(Element_type是一位數(shù)組中存放的數(shù)據(jù)類型,可以是char, int, float, double, etc )

使用qsort之前,必須自己定義一個比較函數(shù)。這個比較函數(shù)用于比較兩個元素的大小。由于qsort可以排序任意數(shù)據(jù)類型,包括自定義的結構類型,因此,做一個自定義的比較函數(shù)是必要的。

int Comp(const void *p1,const void *p2 )

{

???? return *((Element_type *)p2) > *((Element_type *)p1) ? 1 : -1;

}

int main()

{
Element_type list[MAX];

initial(list);

qsort(list, sizeof(list),sizeof(Element_type),Comp); // qsort的4個參數(shù):數(shù)組的首地址、數(shù)組的實際大小,元素的實際大小,比較函數(shù)

return 0;

}

2、對字符串排序:

int Comp(const void *p1,const void *p2)

{

return strcmp((char *)p2,(char *)p1);

}

int main()

{

char a[MAX1][MAX2];

initial(a);

qsort(a,lenth,sizeof(a[0]),Comp);

//lenth 為數(shù)組a的長度

3、按結構體中某個關鍵字排序(對結構體一級排序):

struct Node

{

double data;

int other;

}s[100];

int Comp(const void *p1,const void *p2)

{

return (*(Node *)p2)->data > (*(Node *)p1)->data ? 1 : -1;

}

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

4、按結構體中多個關鍵字排序(對結構體多級排序)[以二級為例]:

struct Node

{
int x;

int y;

}s[100];

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

int Comp(const void *p1,const void *p2)

{

struct Node *c = (Node *)p1;

struct Node *d = (Node *)p2;

if(c->x != d->x) return c->x-d->x;

else return d->y - c->y;

}

5、對結構體中字符串進行排序:

struct Node

{

int data;

char str[100];

}s[100];

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

int Comp(const void *p1,const void *p2)

{

return strcmp((*(Node *)p1).str,(*(Node *)p2).str);

}

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

6、計算幾何中求凸包的Comp

//以下是俺從別人那兒抄來的,暫時還沒用過

int Comp(const void *p1,const void *p2)

//重點Comp函數(shù),把除了1點外的所有的點旋轉(zhuǎn)角度排序

{

struct point *c=(point *)p1;

struct point *d=(point *)p2;

if( cacl(*c, *d,p[1]) < 0) return 1;

else if(!cacl(*c, *d, p[1]) && dis(c->x,c->y,p[1].x,p[1].y) < dis(d->x,d->y,p[1].x,p[1].y ) )

//如果在一條直線上,則把遠的放在前面

return 1;

else return -1;

}

P.S.:qsort函數(shù)是ANSI C標準中提供的,其聲明在stdlib.h文件中,是根據(jù)二分發(fā)寫的,其時間復雜度為n*log(n),其結構為:

void qsort(void *base,size_t nelem,size_t width,int (*Comp)(const void *,const void *));

其中:

*base 為要排序的數(shù)組

nelem 為要排序的數(shù)組的長度

width 為數(shù)組元素的大小(一字節(jié)為單位)

(* Comp)(const void *p1,const void *p2) 為判斷大小函數(shù)的指針,這個函數(shù)需要自己定義,如果p1>p2,函數(shù)返回-1;a<b,函數(shù)返回1;a==b函數(shù)返回0。

轉(zhuǎn)載于:https://www.cnblogs.com/biying/archive/2013/04/19/3031568.html

總結

以上是生活随笔為你收集整理的快排模板的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。