一、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;  
}

关于排序--sort()和qsort()使用的更多相关文章

  1. 排序sort与qsort

    首先看sort函数见下表: 函数名 功能描述 sort 对给定区间所有元素进行排序 stable_sort 对给定区间所有元素进行稳定排序 partial_sort 对给定区间所有元素部分排序 par ...

  2. 转:详细解说 STL 排序(Sort)

    详细解说 STL 排序(Sort) 详细解说 STL 排序(Sort) 作者Winter 详细解说 STL 排序(Sort) 0 前言: STL,为什么你必须掌握 1 STL提供的Sort 算法 1. ...

  3. 详细解说 STL 排序(Sort)(转)

    作者Winter 详细解说 STL 排序(Sort) 0 前言: STL,为什么你必须掌握 1 STL提供的Sort 算法 1.1 所有sort算法介绍 1.2 sort 中的比较函数 1.3 sor ...

  4. stl sort和qsort的使用

    好不容易使用了下stl的qsort函数,顺便和sort函数一起总结下: 很多时候我们都需要用到排序. 例如: 1 #include <iostream> #include <algo ...

  5. C++中sort()及qsort() (不完整介绍)

    在平时刷算法题和oj的时候,排序算法是最经常用到的算法之一:且在各类算法书的目录中 也通常是将各种排序算法放在最前面来讲,可见排序算法的重要性.可能许多人都在算法书中有学过冒泡.快速排序的方法,也都大 ...

  6. 算法学习笔记——sort 和 qsort 提供的快速排序

    这里存放的是笔者在学习算法和数据结构时相关的学习笔记,记录了笔者通过网络和书籍资料中学习到的知识点和技巧,在供自己学习和反思的同时为有需要的人提供一定的思路和帮助. 从排序开始 基本的排序算法包括冒泡 ...

  7. Lucene 排序 Sort与SortField

    在sql语句中,有升序和降序排列.在Lucene中,同样也有. Sort里的属性 SortField里的属性 含义 Sort.INDEXORDER SortField.FIELD_DOC 按照索引的顺 ...

  8. sort 与 qsort

    很长一段时间搞不明白 sort 和 qsort 的区别,平时在写程序时习惯了使用 sort ,因为它用起来比 qsort 要简单的多 , 这里详细介绍一下 sort 与 qsort : 给出一个数组 ...

  9. 设计模式 - 模板方法模式(template method pattern) 排序(sort) 具体解释

    模板方法模式(template method pattern) 排序(sort) 具体解释 本文地址: http://blog.csdn.net/caroline_wendy 參考模板方法模式(tem ...

随机推荐

  1. 现代软件工程HW2:结对编程-生成五则运算式-Core10组 [PB16110698+PB16120162]

    作业具体要求点 这里 Core组要求: 1.Calc() 这个Calc 函数接受字符串的输入(字符串里就是算术表达式,例如 “5*3.5”,“7/8 - 3/8 ”,“3 + 90 * 0.3”等等) ...

  2. drupal7权限控制之-如何访问未发表的node

    在某些特殊需求的情况下,会涉及到匿名用户或非node节点所有者,访问未发表的node节点的需求:或者需要根据不同的用户角色,访问不同的内容类型等,如果不想安装node_access等模块的时候,可以在 ...

  3. leetcode-421-数组中两个数的最大异或值*(前缀树)

    题目描述: 方法一: class Solution: def findMaximumXOR(self, nums: List[int]) -> int: root = TreeNode(-1) ...

  4. Jmeter插件:jp@gc - Dummy Sampler

    Dummy Sampler可以比较方便地模拟测试场景,自定义Request Data和Response Data 1. 安装插件:打开页面插件管理网站,下载plugins-manager.jar. 在 ...

  5. 出现不不能引java.util.Date包的情况

    出现不不能引java.util.Date包的情况 那个时间段不能引,IDE的bug,等一会儿就好了 心得:很多时候没必要和bug死磕,因为真的不是你的问题.

  6. System.Web.Mvc.Filters.IAuthenticationFilter.cs

    ylbtech-System.Web.Mvc.Filters.IAuthenticationFilter.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Cultu ...

  7. 2017/8/4 SCJP学习

    2 Object Orientation . . . . . . . . . . . . . . . . . . . . . . . . . 85 Encapsulation (Exam Object ...

  8. jQuery链式编程时修复断开的链

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. SUMMARY | JAVA中的数据结构

    String String类是不可修改的,创建需要修改的字符串需要使用StringBuffer(线程同步,安全性更高)或者StringBuilder(线程非同步,速度更快). 可以用“+”连接Stri ...

  10. 保持SSH连接的linux服务器不断线

    目录 1. secureCRT和putty连接设置 2. 命令行设置 3. 服务器配置修改 4. 参考 使用ssh连接远程服务器的时候,如果长时间没有操作,远程连接就有可能中断.正在执行的程序和vim ...