C++ sort函数学习笔记

本文介绍了C++中sort函数的使用方法,包括基本排序和自定义排序。通过示例展示了如何实现从大到小排序,以及利用友元函数对结构体进行排序。此外,还提到了less和greater这两个仿函数用于指定排序方向。

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

C++ sort函数学习笔记

使用sort函数需要#include

也可以直接包含万能头文件#include<bits/stdc++.h>

同时要声明命名空间:using namespace std;

sort函数的基本用法

sort(a+m,a+n);//[a+m,a+n)范围内的元素进行排序
sort(a+m,a+n,cmp);//cmp是函数或仿函数

想从大到小排序怎么办?

/*原理是为真的时候,第一个数字放前面*/
bool mycmp(int a,int b)
{
	if(a>b)
	return 1return 0}
    
    int main()
    {
	int i;
    sort(a+0,a+10,mycmp);//数组名+数字的本质是指针操作for(i=0;i<10;i++)
	printf("%d",a[i]);
        return 0}

c++内置了两个比较大小的仿函数less<>,greater<>分别进行大小的比较。

less是从小到大排序,greater是从大到小排序

less和greater的参数都是要比较的数据的数据类型

对结构体进行排序

1、大小比较函数

2、重载运算符

3、仿函数

struct node{
int a,b;
//重载“<”
bool operator<(node B){
	if(a!=B.a)
    	return a<B.a;
   		return b<B.b;
}

什么是友元函数?

在结构体里重载则排序的时候自动使用重载符号,在外面重载则要手动使用,

使用友元函数也可以在sort的时候自动使用。

类的友元函数是定义在类外部,但有权访问类的所有私有(private)成员和保护(protected)成员。尽管友元函数的原型有在类的定义中出现过,但是友元函数并不是成员函数。

友元可以是一个函数,该函数被称为友元函数;友元也可以是一个类,该类被称为友元类,在这种情况下,整个类及其所有成员都是友元。

如果要声明函数为一个类的友元,需要在类定义中该函数原型前使用关键字 friend

---------来自菜鸟教程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hgchshs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值