排序算法之自定义排序函数的含义

我们经常碰到stl容器或者一些排序算法需要用户自定义实现排序规则,为什么要用户自定义排序规则函数呢?请考虑如下场景:

cpp 复制代码
std::vector<int> nums = {1, 3, 2, 5, 4};

// 升序排序(默认)
std::sort(nums.begin(), nums.end(), std::less<int>());
// 或简写为
std::sort(nums.begin(), nums.end());  // 默认使用 operator<

// 降序排序
std::sort(nums.begin(), nums.end(), std::greater<int>());

上面的例子会使用默认的比较函数,用户只需要指定升序还是降序就可以了。但是数据类型不一定都是整型,很有可能是用户自定的类,请看下面的例子:

cpp 复制代码
class Myclass
{
    private:
        std::string name;
        int age;
}

上面的的类型中包含了2个变量,这种情况下应该如何进行排序呢?sort方法肯定没有办法实现这种用户自定义的类型不用成员的排序,那应该怎么办呢?于是sort函数提供了一种方式,即用户自己实现一个函数或者函数对象,这个函数的形式如下:

cpp 复制代码
bool func(T a, T b);
//返回值为布尔型,该函数有两个输入参数,参数的类型都是要进行排序的数据类型
  1. 输入参数a:数据类型为T,这里的T表示的是排序的数据类型,比如上面的例子是类型就是Myclass
  2. 输入参数b:数据类型为T,这里的T表示的是排序的数据类型,比如上面的例子是类型就是Myclass
  3. 返回值:布尔值类型,true的含义是a在b的前面;false的含义是a在b的后面。注意这个函数的含义是a与b比较,若为true,则第一个参数a在第二个参数b前面;若为false,则相反
相关推荐
AI科技星9 小时前
张祥前统一场论动量公式P=m(C-V)误解解答
开发语言·数据结构·人工智能·经验分享·python·线性代数·算法
海琴烟Sunshine9 小时前
leetcode 345. 反转字符串中的元音字母 python
python·算法·leetcode
geobuilding9 小时前
将大规模shp白模贴图转3dtiles倾斜摄影,并可单体化拾取建筑
算法·3d·智慧城市·数据可视化·贴图
jghhh019 小时前
基于高斯伪谱法的弹道优化方法及轨迹仿真计算
算法
mm-q291522272911 小时前
【天野学院5期】 第5期易语言半内存辅助培训班,主讲游戏——手游:仙剑奇侠传4,端游:神魔大陆2
人工智能·算法·游戏
MoRanzhi120311 小时前
Python 实现:从数学模型到完整控制台版《2048》游戏
数据结构·python·算法·游戏·数学建模·矩阵·2048
2401_8414956411 小时前
【数据结构】基于BF算法的树种病毒检测
java·数据结构·c++·python·算法·字符串·模式匹配
蒙奇D索大11 小时前
【算法】递归算法实战:汉诺塔问题详解与代码实现
c语言·考研·算法·面试·改行学it
一只鱼^_12 小时前
力扣第 474 场周赛
数据结构·算法·leetcode·贪心算法·逻辑回归·深度优先·启发式算法
叫我龙翔12 小时前
【数据结构】从零开始认识图论 --- 单源/多源最短路算法
数据结构·算法·图论