sort()排序函数

本文详细讲解了C++中如何使用标准库函数sort()进行整型数组的降序排列,重点介绍自定义排序函数cmp的使用方法。通过实例演示了如何编写cmp函数以根据自定义规则排列数组,并解释了其工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.标准排序:对int,double ,float等数据结构数组进行排序

(1)#include<algorithm>

(2)语法:sort(a,a+n,cmp);

 说明:

1)cmp为判断标准,不写则默认为升序排列

2)实现降序 sort(a,a+n,greater<T>())//T根据数组a类型决定

实现整型数组a,做降序排列:sort(a,a+n,greater<int>())

//int a[n];n表示一数字,不是变量
int a[10];
sort(a,a+10)

2.自定义排序准则——充分利用cmp判断排序函数使用

收藏中有博主书写,这里不写。

仅对如何根据自定义准则来写cmp()做理解梳理;

bool cmp(int x,int y)
{
return x>y;
}
//.....
int main()
{
//..
sort(a,a+n,cmp);
}

(1)实现功能:int类型数组从大到小的排列

(2)理解:(个人的)cmp()为bool类型函数,所返回给sort()为bool值,下,x与y的先后顺序就对应了在a中取值做判断的顺序,所以x的相对位置应该在前面,如果true就不换,false就换。所以实现下来就使得a数组中大的元素在前面,小的数字在后面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值