C++常用函数之sort函数

Posted Jason_Lee155

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++常用函数之sort函数相关的知识,希望对你有一定的参考价值。

C/C++虽然以前学校用过,但是很多STL函数还是不熟悉,遇到一个记录一个吧。


1、sort()函数是C++标准库中的排序函数,头文件为algorithm

2、sort()函数时间复杂度:

我们最熟悉的冒泡排序和选择排序的时间复杂度过高o(n*n),不能满足我们写题的需要。sort函数的排序方法类似于快排方法,时间复杂度为n*log2(n)

3、sort()函数的参数

sort(起始地址,结束地址,比较器);        其中比较器可以省略,默认升序

int arr[10]=5,3,6,0,2,8,2,6,9,11;
sort(arr,arr+10);

带比较器的写法(比较器可以根据自身的需要来写,当返回true时):

//首先我们要写一个bool类型的方法,用来返回参数的比较结果
//当比较器返回true时,第一个参数放在前面,第二个参数放在后面,即位置不变
//当比较器返回false时,为两元素交换位置
//这里要注意对参数相等时的处理
//因为可能会在两者相等的时候交换位置,在一些特定的环境下会导致题解出错
bool cmp1(int lhs,int rhs)//升序

	return lhs<rhs;

bool cmp2(int lhs,int rhs)//降序

	return lhs>rhs;

sort(arr,arr+10,cmp1);//升序
sort(arr,arr+10,cmp1);//降序

4、对vector排序

vector<int> vec=5,3,6,0,2,8,2,6,9,11;
//比较器同对数组排序
sort(vec.begin(),vec.end(),cmp1);
sort(vec.begin(),vec.end(),cmp2);

5、对map进行排序

这里要注意,map函数有一个按key值进行的自动排序功能(升序)

typedef pair<int,int> PAIR;
//比较器
//按value值进行降序排序,value值相等key小的在前
bool cmp_value(const PAIR& lhs,const PAIR& rhs)

	if(lhs.second == rhs.second)
	
		return lhs.key<rhs,second;
	
	return lhs.second > rhs.second;

sort(m.begin(),m,end(),cmp_value);

以上是关于C++常用函数之sort函数的主要内容,如果未能解决你的问题,请参考以下文章

C++排序函数

pytorch :使用两次sort函数(排序)找出矩阵每个元素在升序或降序排列中的位置

pytorch :使用两次sort函数(排序)找出矩阵每个元素在升序或降序排列中的位置

PHP常用数组函数2

php之快速入门学习-11(数组排序)

JavaScript sort函数的使用