C/C++ sort函数的用法
来源:互联网 发布:c语言web攻击脚本 编辑:程序博客网 时间:2024/06/03 19:50
转载:http://blog.sina.com.cn/s/blog_6439f26f01012xw3.html
C/C++ sort函数的用法
(2012-03-11 12:15:32)it
分类:C/CPlusPlussort函数的用法
做ACM题的时候,排序是一种经常要用到的操作。如果每次都自己写个冒泡之类的O(n^2)排序,不但程序容易超时,而且浪费宝贵的比赛时间,还很有可能写错。STL里面有个sort函数,可以直接对数组排序,复杂度为n*log2(n)。使用这个函数,需要包含头文件。
bool cmp(int a,int b)
{
}
struct node{
}
以下是代码片段:
bool cmp(node x,node y)
{
if(x.b!=y.b) returnx.b>y.b;
}
qsort(s[0],n,sizeof(s[0]),cmp);
int cmp(const void *a,const void *b)
{
}
一、对int类型数组排序
intnum[100];
Sample:
int cmp ( const void *a , const void *b)
{
return *(int *)a - *(int*)b;
}
qsort(num,100,sizeof(num[0]),cmp);
二、对char类型数组排序(同int类型)
charword[100];
Sample:
int cmp( const void *a , const void *b)
{
return *(char *)a - *(int*)b;
}
qsort(word,100,sizeof(word[0]),cmp);
三、对double类型数组排序(特别要注意)
doublein[100];
int cmp( const void *a , const void *b)
{
return *(double *)a > *(double *)b ? 1 :-1;
}
qsort(in,100,sizeof(in[0]),cmp);
四、对结构体一级排序
structIn
{
double data;
int other;
}s[100]
//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写
int cmp( const void *a ,const void*b)
{
return ((In *)a)->data - ((In*)b)->data;
}
qsort(s,100,sizeof(s[0]),cmp);
五、对结构体
structIn
{
int x;
int y;
}s[100];
//按照x从小到大排序,当x相等时按照y从大到小排序
int cmp( const void *a , const void *b)
{
struct In *c = (In *)a;
struct In *d = (In *)b;
if(c->x != d->x) returnc->x -d->x;
else return d->y -c->y;
}
qsort(s,100,sizeof(s[0]),cmp);
六、对字符串进行排序
structIn
{
int data;
char str[100];
}s[100];
//按照结构体中字符串str的字典顺序排序
int cmp ( const void *a , const void *b)
{
return strcmp( ((In *)a)->str , ((In*)b)->str);
}
qsort(s,100,sizeof(s[0]),cmp);
七、计算几何中求凸包的cmp
int cmp(const void *a,const void *b)//重点cmp函数,把除了1点外的所有点,旋转角度排序
{
struct point *c=(point*)a;
struct point *d=(point*)b;
if( calc(*c,*d,p[1]) < 0) return1;
else if( !calc(*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;
}
- C++sort函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort()函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort函数的用法
- C++sort()函数的用法
- C++sort()函数的用法
- C++sort函数的用法
- c++sort函数的用法
- C++sort 函数用法
- C++sort 函数用法
- C++sort 函数用法
- web
- TCP/IP三次握手、四次挥手总结
- 有一篇文章,共有3行文字,每行有10个字符。要求分别统计出其中英文大写字母、小写字母、数字、空格及其它字符的个数
- hadoop完全分布式搭建问题
- Win32SDK编辑框控件的简单操作
- C/C++ sort函数的用法
- 2015 股市小牛 记载
- 【HDU 4609】3-idiots(FFT)
- Java基础——内部类
- 玩转嵌入式系统
- 用JavaScript做浏览器对象事件的兼容性
- 面向不一致的coding
- Yii查询生成器(Query Builder)用法实例教程
- fft