最近学弟们问快速排序的比较多,今天自己就做一下总结,快速排序在库函数里面有现成的,不用自己实现,调用一下就可以达到自己想要的结果,掌握以后就可以完全摒弃冒泡和选择了,并且时间复杂度也从O(n*n)提升到O(n*log(n)),

先说C中的qsort():

  头文件:#include<stdlib.h>,

  调用参数:qsort(排序首地址,需排序元素个数,需排序元素大小,定义排序方式的函数名);

  1,对int型数组a[n]排序:

    int cmp (const void *a, const void *b)
    {
      return *(int *)a - *(int *)b;
    }//升序

    int cmp (const void *a, const void *b)
    {
      return *(int *)b - *(int *)a;
    }//降序

  2,对字符串数组a[n]排序:

    int cmp (const void *a, const void *b)
    {
      return strcmp((char *)a, (char *)b);
    }//升序

    int cmp (const void *a, const void *b)
    {
      return strcmp((char *)b, (char *)a);
    }//降序

  3,对结构体数组a[n]排序

    struct node
    {
      int x, y;
    };

    int cmp (const void *a, const void *b)
    {
      node *c = (node *)a;
      node *d = (node *)b;
      return c->x - d->x;
    }//按照a[i].x升序排列

    int cmp (const void *a, const void *b)
    {
      node *c = (node *)a;
      node *d = (node *)b;
      return d->x - c->x;
    }//按照a[i].x降序排列

    ps:结构体的二级排序只需要再加上一个if条件语句即可。

    以上所有的排序函数,使用时都是调用qsort(a, n, sizeof(a[0]), cmp);

C++中的sort函数:其实有时候sort函数比qsort函数还要稍微快那么一点,并且用起来比较方便,所以在这里做一下广告,有排序用sort函数,不能用创造机会也要用!!!

  头文件:#include<algothrim>

  调用参数:sort(排序首地址,排序末地址,定义排序方式的函数名(可有可无)),如果没有排序方式默认按照升序排列。

  现在我们就解决一下如何按照降序方式排列。

  1,对int型数组a[n]降序排:

  bool cmp (int a, int b)
  {
    return a > b;
  }//降序

  2,对string型的数组a[n]排序:

  bool cmp (string a, string b)
  {
    return a > b;
  }//降序

  3,对结构体型的数组a[n]排序:

  bool cmp (node a, node b)
  {
    return a.x > b.x;
  }//降序

  ps:如果对结构体进行二级排序,只需在排序函数里面加上if语句。

  以上所有的排序函数调用的时候都是用:sort(a, a+n, cmp);

  其实强大的stl库给我们提供了辣么多的函数,有一些在这里还是很有用的,比如:

  sort(a, a+n, less<数据类型>());//对指定的数据类型升序排

  sort(a, a+n, greater<数据类型>());//对指定的数据类型降序排

因为C/C++给我们提供给了太多的数据类型,所以上面只是一些常见的数据类型的排序。

    

    

C/C++中qsort()以及sort()的用法的更多相关文章

  1. qsort()与sort的用法(收藏)

    sort()函数是C++中的排序函数其头文件为:#include<algorithm>头文件: qsort()是C中的排序函数,其头文件为:#include<stdlib.h> ...

  2. STL中find和sort的用法总结

    STL算法 STL 提供能在各种容器中通用的算法(大约有70种),如插入.删除.查找.排序等. 许多算法操作的是容器上的一个区间(也可以是整个容器),因此需要两个参数,一个是区间起点元素的迭代器,另一 ...

  3. python中List的sort方法的用法

    python列表排序 简单记一下python中List的sort方法(或者sorted内建函数)的用法. 关键字: python列表排序 python字典排序 sorted List的元素可以是各种东 ...

  4. 【转】python中List的sort方法(或者sorted内建函数)的用法

    原始出处:http://gaopenghigh.iteye.com/blog/1483864 python列表排序 简单记一下python中List的sort方法(或者sorted内建函数)的用法. ...

  5. hive中order by,sort by, distribute by, cluster by作用以及用法

    1. order by     Hive中的order by跟传统的sql语言中的order by作用是一样的,会对查询的结果做一次全局排序,所以说,只有hive的sql中制定了order by所有的 ...

  6. [转载]hive中order by,sort by, distribute by, cluster by作用以及用法

    1. order by     Hive中的order by跟传统的sql语言中的order by作用是一样的,会对查询的结果做一次全局排序,所以说,只有hive的sql中制定了order by所有的 ...

  7. C++ sort函数用法

    参考文档:http://hi.baidu.com/posinfo/item/dc3e73584c535cc9d2e10c27 C++ sort函数用法 FROM:http://hi.baidu.com ...

  8. qsort与sort

    快排是我们平常敲代码和比赛的时候     经常使用到的方法 qsort是函数库中自带的函数    这是一个标准的快排函数 而sort比qsort更是好用    sort对于不同大小的数组   会使用不 ...

  9. 引用 qsort与sort的比较

    引用 linpder 的 qsort与sort的比较     在C/C++标准库中提供了快速排序的函数qsort():在STL中也提供了sort()排序函数,那么这两个函数哪个快呢?之前与代码-> ...

随机推荐

  1. 如何实现1080P延迟低于500ms的实时超清直播传输技术<转>

    转载地址:http://www.yunweipai.com/archives/9037.html 最近由于公司业务关系,需要一个在公网上能实时互动超清视频的架构和技术方案.众所周知,视频直播用 CDN ...

  2. fontconfig

    vlc-android 默认是 禁用 fontconfig 的 如果想要使用的话需要手动修改 compile.sh

  3. Ubuntu安装Chrome及hosts修改

    Ubuntu16.04 1.chrome安装 获取安装包http://www.google.cn/chrome/browser/desktop/index.html 在安装包目录打开终端执行sudo  ...

  4. Android基础学习:Android环境搭建

    在3年前,自学过Android的一些基础知识,但是那个时候Linux等其他的知识结构比较薄弱,理解得不是很深刻,后来因项目变动的原因,没有再搞Android相关的东西了.时过境迁,还是因为项目变动,重 ...

  5. 4-5 父节点watcher事件

    三种方式设置watcher:ls.stat.get

  6. cocos2d-js 序列帧动画

    var spriteCache = cc.spriteFrameCache;spriteCache.addSpriteFrames(res.fireworks_plist,res.fireworks_ ...

  7. 适合新手的Python爬虫小程序

    介绍:此程序是使用python做的一个爬虫小程序  爬取了python百度百科中的部分内容,因为这个demo是根据网站中的静态结构爬取的,所以如果百度百科词条的html结构发生变化 需要修改部分内容. ...

  8. ZROI2018提高day1t3

    传送门 分析 考场上想到了先枚举p的长度,在枚举这个长度的所有子串,期望得分40~50pts,但是最终只得了20pts,这是因为我写的代码在验证中总是不断删除s'中的第一个p,而这种方式不能解决形如a ...

  9. Luogu 1484 种树

    Luogu 1792 算是双倍经验. 我们考虑对于一个点,我们要么选它,要么选它周围的两个点. 所以我们考虑用一个堆来维护,每次从堆顶取出最大值之后我们把它的权值记为:它左边的权值加上它右边的权值减去 ...

  10. spark sql的应用场景

    最近一直在银行做历史数据平台的项目,目前整个项目处于收尾的阶段,也好有时间整理下在项目中的一些收获. 该历史数据平台使用spark+Nosql架构了,Nosql提供了海量数据的实时查询,而spark提 ...