最近学弟们问快速排序的比较多,今天自己就做一下总结,快速排序在库函数里面有现成的,不用自己实现,调用一下就可以达到自己想要的结果,掌握以后就可以完全摒弃冒泡和选择了,并且时间复杂度也从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. C#封装CRUD到SqlHelper类解读

    1.简单说明一下,一般情况下,数据库连接字符串是在App.config文件中进行配置,然后再在代码中进行引用.因此,我们在这里先看一下App.config文件. 首先看需要添加的内容: 参数说明: n ...

  2. PAT-l3-002堆栈

    L3-002. 堆栈 大家都知道“堆栈”是一种“先进后出”的线性结构,基本操作有“入栈”(将新元素插入栈顶)和“出栈”(将栈顶元素的值返回并从堆栈中将其删除).现请你实现一种特殊的堆栈,它多了一种操作 ...

  3. 标签控件JLabel的使用

    ---------------siwuxie095                             工程名:TestUI 包名:com.siwuxie095.ui 类名:TestLabel.j ...

  4. IFC数据模型在三维引擎中模拟

  5. ROS Learning-017 Arduino-For-ROS-002 第一个程序: Hello World

    Arduino For ROS-002 - 第一个程序: Hello World 我的Ubuntu系统:Ubuntu 14.04.10 TLS 32位 Arduino的版本:Arduino 1.6.1 ...

  6. JavaPersistenceWithHibernate第二版笔记-第六章-Mapping inheritance-005Table per subclass with joins(@Inheritance(strategy = InheritanceType.JOINED)、@PrimaryKeyJoinColumn、)

    一.结构 The fourth option is to represent inheritance relationships as SQL foreign key associations. Ev ...

  7. Luogu 3466 [POI2008]KLO-Building blocks

    BZOJ 1112. 题意相当于在一个长度为$k$的区间内选择一个数$s$使$\sum_{i = 1}^{k}\left | a_i - s \right |$最小. 很显然是中位数. 然后只要写一个 ...

  8. vue 之 表单输入绑定

    vue的核心:声明式的指令和数据的双向绑定. 那么声明式的指令,已经给大家介绍完了.接下来我们来研究一下什么是数据的双向绑定? 另外,大家一定要知道vue的设计模式:MVVM M是Model的简写,V ...

  9. javax.servlet.http.httpServletRequest接口

    HttpServletRequest接口中常用的方法:   - String getContentPath();//获取webapp根目录路径,如下图:   下面研究request到底是一个怎样的范围 ...

  10. 遍历一个二维数组的简便方法(减少foreach次数)

    在一些特定场合可以使用下, 还是有局限性 输出结果 : 另一种场景 : 输出结果 : 更复杂的场景 : 输出结果 :