c++入门必学库函数 sort
admin
2024-04-02 13:13:08
0

一、sort 的介绍

sort是c++ algorithm 库里的一个排序函数。排序太常用了,如果每次都要自己写排序函数的话会浪费程序员大量的时间和精力,所以函数库里就写好了一些排序算法以供我们使用。

sort()是不稳定的排序,底层使用的是快速排序算法,平均时间复杂度为O(n*log n)

如果需要稳定排序可以使用stable_sort(),底层使用归并排序实现的,时间复杂度固定是O(n*log n)

sort()和stable_sort()用法是一样的,下面我们只讲解sort()的使用

二、sort的基本用法

sort(起始地址,末尾地址+1);
sort(起始地址,末尾地址+1,cmp);

sort是默认升序排序的,如果需要自定义排序,可以写一个比较函数,用第二种方法排序

1、普通数组的排序

示例代码:

#include
#include //使用sort等算法函数需要的头文件 
using namespace std;
void print(int a[]){//打印函数 for(int i=0;i<10;i++){cout<//大于号是升序排序,小于号是降序排序 return a1>a2;
}int main(){int a[10]={3,1,4,5,8,0,9,2,7,6};cout<<"排序前:"<

运行结果:

排序前:
3 1 4 5 8 0 9 2 7 6sort(a,a+10)排序后:
0 1 2 3 4 5 6 7 8 9sort(a,a+10,cmp)自定义降序排序后:
9 8 7 6 5 4 3 2 1 0

2、结构体的排序

因为结构体默认是没有比较大小的功能的,所以我们必须使用cmp函数定义排序方法

示例代码:

#include
#include //使用sort等算法函数需要的头文件 
using namespace std;
struct test{int a;int b;
}; bool cmp1(test t1,test t2){//先按a升序排序,再按b升序排序 if(t1.a==t2.a){return t1.b//先按a降序排序,再按b降序排序 if(t1.a==t2.a){return t1.b>t2.b;}return t1.a>t2.a;
}void print(test t[]){for(int i=0;i<5;i++){cout<<"t["<test t[5];t[0].a=2;t[0].b=3;t[1].a=5;t[1].b=3;t[2].a=5;t[2].b=2;t[3].a=2;t[3].b=8;t[4].a=1;t[4].b=1;cout<<"排序前:"<

运行结果:

排序前:
t[0](2,3) t[1](5,3) t[2](5,2) t[3](2,8) t[4](1,1)sort(a,a+5,cmp1)自定义升序排序后:
t[0](1,1) t[1](2,3) t[2](2,8) t[3](5,2) t[4](5,3)sort(a,a+5,cmp2)自定义降序序排序后:
t[0](5,3) t[1](5,2) t[2](2,8) t[3](2,3) t[4](1,1)

3、vector等数据结构的排序

像vector和string等数据结构,我们排序时是不能像数组那样直接用名字代表地址来排序的,而必须使用它们的迭代器begin()和end()来完成排序

示例代码:

#include
#include //使用vector容器需要使用这个头文件 
#include //使用sort等算法函数需要的头文件 
using namespace std;print(vector v){//打印函数 for(int i=0;icout<vector v;//定义一个int型的vector v.push_back(2);//在尾部插入一个元素2 v.push_back(3);//在尾部插入一个元素3v.push_back(7);v.push_back(1);v.push_back(9);v.push_back(8);v.push_back(0);v.push_back(5);v.push_back(4);cout<<"排序前:"<

运行结果:

排序前:
2 3 7 1 9 8 0 5 4sort(v.begin(),v.end())升序排序后:
0 1 2 3 4 5 7 8 9sort(v.rbegin(),v.rend())降序排序后:
9 8 7 5 4 3 2 1 0

当然,vector等结构都是可以用cmp函数自定义排序方法的,感兴趣的同学可以尝试一下,这里就不在叙述了,因为都是大同小异的。学会举一反三学习效率才会高

加油!!兄弟萌

点个赞呗

相关内容

热门资讯

德国商业银行CEO:随时准备收... 德国商业银行首席执行官近日表示,银行随时准备展开收购谈判,展现出其在市场并购活动中的积极姿态。这一声...
央行:金融机构应在开展客户尽职... 10月11日消息,央行就《金融机构客户受益所有人识别管理办法(征求意见稿)》公开征求意见。《办法》参...
前9月广州海关共办理离境退税验... 10月11日消息,第138届中国进出口商品交易会将于10月15日至11月4日分三期在广州举行。目前,...
上海:已设立总规模约150亿元... 10月11日消息,上海市科委副主任屈炜在上海市政府新闻发布会上透露,目前,上海市已设立总规模约150...
高盛:预计2026/2027年... 10月11日消息,高盛周五在一份报告中称,预计2026/2027年铜价将维持在每吨1万-1.1万美元...
年内因财务造假实质触及重大违法... 10月11日消息,据公开信息,截至10月10日,今年以来因财务造假而实质触及重大违法强制退市指标的公...
欧股涨幅扩大 德国DAX指数日内涨幅扩大至3%,英国富时100指数涨2.38%,法国CAC40指数涨超3%。 (本...
中国移动:2028年底人工智能... 10月11日消息,在2025中国移动全球合作伙伴大会主论坛上,中国移动正式发布“AI+”行动计划升级...
中国石油集团董事长戴厚良会见土... 10月11日消息,中国石油集团董事长戴厚良10日会见土库曼斯坦天然气康采恩副总裁阿尔恰耶夫,双方就天...
现货白银周五涨超2%,黄金本周... 10月11日消息,周五(10月10日)纽约尾盘,现货黄金涨0.85%,报4010.62美元/盎司,本...