sort函数见下表:
函数名 功能描述
sort 对给定区间所有元素进行排序
stable_sort 对给定区间所有元素进行稳定排序
partial_sort 对给定区间所有元素部分排序
partial_sort_copy 对给定区间复制并排序
nth_element 找出给定区间的某个位置对应的元素
is_sorted 判断一个区间是否已经排好序
partition 使得符合某个条件的元素放在前面
stable_partition
相对稳定的使得符合某个条件的元素放在前面
sort函数的用法(C++排序库函数的调用)
对数组进行排序,在c++中有库函数帮我们实现,这们就不需要我们自己来编程进行排序了。
(一)为什么要用c++标准库里的排序函数
Sort()函数是c++一种排序方法之一,学会了这种方法也打消我学习c++以来使用的冒泡排序和选择排序所带来的执行效率不高的问题!因为它使用的排序方法是类似于快排的方法,时间复杂度为n*log2(n),执行效率较高!
(二)c++标准库里的排序函数的使用方法
I)Sort函数包含在头文件为#include<algorithm>的c++标准库中,调用标准库里的排序方法可以不必知道其内部是如何实现的,只要出现我们想要的结果即可!
II)Sort函数有三个参数:
(1)第一个是要排序的数组的起始地址。
(2)第二个是结束的地址(最后一位要排序的地址的下一地址)
(3)第三个参数是排序的方法,可以是从大到小也可是从小到大,还可以不写第三个参数,此时默认的排序方法是从小到大排序。
Sort函数使用模板:
Sort(start,end,排序方法)
下面就具体使用sort()函数结合对数组里的十个数进行排序做一个说明!
例一:sort函数没有第三个参数,实现的是从小到大
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
int a[10]={9,6,3,8,5,2,7,4,1,0};
for(int i=0;i<10;i++)
cout<<a[i]<<endl;
sort(a,a+10);
for(int i=0;i<10;i++)
cout<<a[i]<<endl;
return 0;
}
例二
通过上面的例子,会产生疑问:要实现从大到小的排序肿么办?
这就如前文所说需要在sort()函数里的第三个参数里做文章了,告诉程序我要从大到小排序!
需要加入一个比较函数complare(),此函数的实现过程是这样的
1
2
3
4
bool complare(int a,int b)
{
return a>b;
}
这就是告诉程序要实现从大到小的排序的方法!
#include<iostream>
#include<algorithm>
using namespace std;
bool compare(int a,int b)
{
return a>b;
}
int main()
{
int a[10]={9,6,3,8,5,2,7,4,1,0};
for(int i=0;i<10;i++)
cout<<a[i]<<endl;
sort(a,a+10,compare);//在这里就不需要对compare函数传入参数了,
//这是规则
for(int i=0;i<10;i++)
cout<<a[i]<<endl;
return 0;
}
假设自己定义了一个结构体node
struct node
{
int a;
int b;
double c;
}
有一个node类型的数组node arr[100],想对它进行排序:先按a值升序排列,如果a值相同,再按b值降序排列,如果b还相同,就按c降序排列。就可以写这样一个比较函数:
以下是代码片段:
bool cmp(node x,node y)
{
if(x.a!=y.a) return x.a<y.a;
if(x.b!=y.b) return x.b>y.b;
return x.c>y.c;
}

最新文章

  1. php使用post方式获得文件扩展名
  2. centos 7 mini装maridb 10.1 binary版本
  3. Android 对话框(Dialog)大全 建立你自己的对话框
  4. jQuery效果之隐藏与显示、淡入淡出、滑动、回调
  5. 返回绝对值--Math.Abs 方法
  6. nodeAPI--HTTP
  7. eclipse批量删除断点(转)
  8. BIP_Oracle Erp标准银行接口XML文件(案例)(待整理)
  9. Friendship of Frog(水题)
  10. codeforces 868B Race Against Time
  11. 如何在centos操作系统上发布.net core的项目
  12. UEditor之实现配置简单的图片上传示例
  13. s21day16 python笔记
  14. 【Convex Optimization (by Boyd) 学习笔记】Chapter 2 - Convex sets(1) 仿射集&amp;凸集
  15. 扫盲记-第六篇--Normalization
  16. 深入理解 Vue 组件
  17. 静态类和静态方法,抽象类和抽象方法,new关键字,值类型和引用类型,接口
  18. 在CentOs6.5安装jdk
  19. iTunes历史各个版本下载地址
  20. css字体属性相关。

热门文章

  1. 举例实用详解sc.textFile()和wholeTextFiles()
  2. mysql 取整
  3. go实现set
  4. require.js 模块化简单理解
  5. CentOS查找文件命令
  6. 初识SeekBar
  7. JavaScript_4_数据类型
  8. cmd下查询端口占用以及根据进程id名称结束进程
  9. 四、filter和find函数的区别
  10. Acronis.Disk.Director磁盘分区管理