C++ 中的sort()排序函数原理、用法看这一篇就够了

C++ 中的sort()排序函数原理、用法用法看这一篇就够了

sort(first_pointer,first_pointer+n,cmp)

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

原理:sort并不是简单的快速排序,它对快速排序进行了优化。此外,它还结合了插入排序和推排序。系统会根据数据形式和数据量自动选择合适的排序方法。它每次排序中不只选择一种方法,比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。

3个参数:

参数1:第一个参数是数组的首地址,一般是数组名或者迭代器。

参数2:要排序数据的尾地址。

参数3:默认可以不填,如果不填sort会默认按数组升序排序。可以自定义一个排序函数,改排序方式为降序。

使用此函数需先包含:

#include < algorithm >
using namespace std;

自己编写排序规则函数

bool compare(int a,int b)
{
return a<b; //升序排列
}

sort扩展

sort不只是能像上面那样简单的使用,我们可以对sort进行扩展,关键就在于第三个参数<cmp比较函数>。

方法一:定义比较函数(最常用)
//情况一:数组排列

int A[100];
bool cmp1(int a,int b)//int为数组数据类型
{
return a>b;//降序排列
//return a<b;//默认的升序排列
}
sort(A,A+100,cmp1);

//情况二:结构体排序

Student Stu[100];
bool cmp2(Student a,Student b)
{
return a.id>b.id;//按照学号降序排列
}
sort(Stu,Stu+100,cmp2);

注:比较方法也可以放在结构体中或类中定义。

方法二:使用标准库函数

functional提供了一堆基于模板的比较函数对象:equal_to、not_equal_to、greater、greater_equal、less、less_equal。
● 升序:sort(begin,end,less())

● 降序:sort(begin,end,greater())

缺点:也只是实现简单的排序,结构体不适用。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <functional>

using namespace std;
//简单使用方法
sort(A,A+100,greater<int>());//降序排列
sort(A,A+100,less<int>());//升序排列

方法三:重载结构体或类的比较运算符

//情况一:在结构体内部重载
typedef struct Student{
int id;
string name;
double grade;

bool operator<(const Student& s)
{
return id>s.id;//降序排列
//return id<s.id;//升序排列
}
};
vector<Student> V;
sort(V.begin(),V.end());

//情况二:在外部重载

vector<Student> V;
bool operator<(const Student& s1, const Student& s2)
{
return s1.id>s2.id;//降序排列
//return s1.id<s2.id;//升序排列
}
sort(V.begin(),V.end());

注意:一定要重载<运算符,因为系统默认是降序,用的是<运算符。

方法四:声明比较类(少用)

struct Less
{
bool operator()(const Student& s1, const Student& s2)
{
return s1.id<s2.id; //升序排列
}
};
sort(sutVector.begin(),stuVector.end(),Less());
  • 51
    点赞
  • 144
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
C语言sort函数是用于对数组进行排序函数。它使用的是一种被称为快速排序(Quicksort)的算法来进行排序。快速排序的基本思想是通过分治法将一个大问题分解为若干个小问题来解决。具体来说,快速排序的步骤如下: 1. 选择一个基准元素(pivot)作为参考点。 2. 将数组分为两部分,一部分是比基准元素小的元素,一部分是比基准元素大的元素。这个过程被称为划分(partition)。 3. 对划分后的两部分进行递归地重复步骤1和步骤2,直到每个子数组只包含一个元素或者为空。 4. 将所有的子数组合并起来,得到最终排序后的数组。 在实现快速排序时,我们可以选择不同的策略来选择基准元素,比如选择第一个元素、最后一个元素、间元素或者随机元素作为基准元素。此外,还可以采用三数取法来选择基准元素,以提高排序的效率和减少最坏情况出现的概率。 需要注意的是,sort函数是一个标准库函数,其内部实现可能有所不同,但基本的原理和步骤是相似的。对于不同的编译器和系统,可能会有一些优化或者特殊处理,以提高排序的性能或者适应特定的场景。因此,在使用sort函数时,可以参考相关的文档或者资料,了解具体的实现细节和使用方法。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [C++sort函数的基础入门使用教程](https://download.csdn.net/download/weixin_38713717/12753142)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [超详细Java入门到精通自学视频课程-09、继承:特点、访问特点、方法重写.rar](https://download.csdn.net/download/weixin_54787054/88280695)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值