C++中STL包含的sort()函数的用法

1,该函数可以给数组,或者链表list、向量排序。

转自该博客https://blog.csdn.net/l198738655/article/details/79872738
实现原理:sort并不是简单的快速排序,它对普通的快速排序进行了优化,此外,它还结合了插入排序和推排序。系统会根据你的数据形式和数据量自动选择合适的排序方法,这并不是说它每次排序只选择一种方法,它是在一次完整排序中不同的情况选用不同方法,比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。

此函数有3个参数:

参数1:第一个参数是数组的首地址,一般写上数组名就可以,因为数组名是一个指针常量。

参数2:第二个参数相对较好理解,即首地址加上数组的长度n(代表尾地址的下一地址)。

参数3:默认可以不填,如果不填sort会默认按数组升序排序。也就是1,2,3,4排序。也可以自定义一个排序函数,改排序方式为降序什么的,也就是4,3,2,1这样。

sort不只是能像上面那样简单的使用,我们可以对sort进行扩展,关键就在于第三个参数<cmp比较函数>,我们想降序排列,或者说我不是一个简简单单的数组,而是结构体、类怎么办,下面给出一些方法和例子。

2,对vector进行排序:

参考该博客https://blog.csdn.net/qianlixiaomage/article/details/81205584

sort()函数使用方法以及参数规定

1.假如你定义的vector变量为vector num,则如下:
sort(num.begin(), num.end(), sortFun); //sortFun代表排序方式。
2,如果是基本类型假如是int,第三个参数可以使用系统自带的less()或者greater();
3,,自定义类型话或者复杂类型就需自己定义比较规则函数sortFun,

基本类型int 示范举例:

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
	int n;
	cin >> n;
	vector<int> num(n, 0);
	for (int i = 0; i < n; i++)
		cin >> num[i];
	sort(num.begin(), num.end(), less<int>());
	for (int i = 0; i < n; i++)
	{
		cout << num[i] << " ";
	}
	return 0;

猜你喜欢

转载自blog.csdn.net/Crazy__1/article/details/88709902