一、sort()函数的使用

使用sort()函数的时候要加上头文件#include<algorithm>和using namespace std。
这个函数接收两个或者三个参数。
第一个参数是区间的首地址,第二个参数是区间尾地址的下一个地址,也就是说排序的区间是[a,b).

简单说就是对于int a[len],要对a[0]到a[len-1]进行排序,调用sort(a,a+len)即可。默认的是升序。

排序的数据类型不局限于整数,只要定义了小于运算的类型都是可以的,如string。

如果没有定义小于运算的数据类型,或者改变一下排序的规则,这个时候就要使用第三个参数--比较函数。 
比较函数是用户自定义的函数,返回bool类型,这个函数规定了用户自定义的“小于”如果想进行降序排列,如下:
bool cmp(int a,int b)
{
    return a>b;
}
sort(a,a+len,cmp)


例子:有一个node类型的数组node arr[100],想对其按照如下规则进行排序:
先按a的值升序排序,如果a的值相同,在按b的值降序排序,如果b还相同,就按c的值降序排序。那么cmp()函数为:
struct node
{
    int a;
    int b;
    double c;
}

bool cmp(node x,node y)
{
    if(x.a!=y.a)            return x.a<y.a;
    else if(x.b!=y.b)     return x.b>y.b
    else if(x.c!=x.c)      return x.c>y.c;
}
sort(arr,arr+100,cmp);




二、qsort()函数的使用
qsort()是C中的排序函数,其头文件是#include<stdio.h>
sort()是C++中的排序函数,其头文件是#include<algorithm>

函数原型:
void  qsort( void *base, size_t num, size_t width, int (__cdecl *cmp ); int  cmp (const void *elem1, const void *elem2 ) ); 

参数意义:
base:需要排序的目标数组开始地址
num:目标数组元素个数
width:目标数组中每一个元素的长度
cmp:函数指针,指向比较函数


1、对int类型数组排序
int num[100];
int cmp(const void *a,const void *b)
{
    return *(int *)a-*(int *)b;
}
qsort(num,100,sizeof(num[0]),cmp);


2、对char类型数组排序
char word[100];
int cmp(const void *a,const void *b)
{
    return *(char *)a-*(char *)b;
}
qsort(word,100,sizeof(word[0]),cmp);


3、对double类型数组排序
double in[100];
int cmp(const void *a,const void *b)
{
    return *(double *)a>*(double *)b?1:-1;
}
qsort(in,100,sizeof(in[0]),cmp);


4、对结构体排序
struct In  
{  
    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);  


struct In  
{  
    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) 
        return c->x - d->x;  
    else 
        return d->y - c->y;  
}  
qsort(s,100,sizeof(s[0]),cmp);  


struct In  
{  
    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);  



5、计算几何中凸包的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)
         return 1;  
    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;  
}

最新文章

  1. 视图必须派生自 WebViewPage 或 WebViewPage&lt;TModel&gt;
  2. nginx 499 状态码优化
  3. 转~~~ DIV+CSS实现三角形提示框
  4. Linux运行与控制后台进程的方法:nohup, setsid, &amp;, disown, screen
  5. POJO, DTO, VO, JavaBean的区别
  6. Python学习笔记(0)
  7. Android:布局实例之模仿微信Tab
  8. Mac 配置jdk
  9. 替换SQL Server数据库中所有表的所有字段的某些内容
  10. openStack ceilometer API
  11. NS2仿真:公交车移动周期模型及性能分析
  12. collection系列用法-deque双向队列
  13. MySQL 5.7.10 免安装配置
  14. read运行
  15. springboot快速入门
  16. Python——递归函数
  17. LeetCode:21_Merge Two Sorted Lists | 合并两个排序列表 | Easy
  18. JS图片水印
  19. springmvc源码解析(二)
  20. Py脚本运行后暂停不退出

热门文章

  1. 【noi.ac-CSP-S全国模拟赛第三场】#705. mmt
  2. splice用法
  3. 去哪儿的 源码 个人解析(2) router
  4. 一个切图仔的HTML笔记
  5. 单独编译和使用webrtc音频增益模块(附完整源码+测试音频文件)
  6. vue中export和export default的使用
  7. nodejs与websocket模拟简单的聊天室
  8. idea从github中pull或者push成功之后tomcat启动不了,报Error....
  9. python编码(31-01)
  10. 初识OpenCV-Python - 010: 精致边缘探测