C++复习笔记--自定义比较器的使用(仿函数实现)

目录

1--比较器的优点

2--比较器的规则

3--代码实例


1--比较器的优点

比较器的实质是重载比较运算符;

比较器可以很好地应用在特殊标准的排序中;

比较器可以很好地应用在根据特殊标准排序的结构上;

2--比较器的规则

一开始参数的前后顺序与函数传入参数的前后顺序一致,即对于 function(T v1, T v2) 的初始顺序是 v1 在前面,v2 在后面,根据排序规则确定是否交换顺序;

返回正数(true)的时候,不交换顺序(第一个参数在前面);

返回负数(false)的时候,交换顺序(第一个参数在后面);

3--代码实例

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>

class Person{
public:
    Person(std::string n, int a, int s) : age(a),  name(n), score(s) {};
    std::string name;
    int age;
    int score;
};

class Compare1{
public:
    bool operator()(Person v1, Person v2){
        // 按照年龄降序排列
        return v1.age > v2.age; // 返回 true 时, v1 在前面 
    }
};

class Compare2{
public:
    bool operator()(Person v1, Person v2){
        // 按照成绩升序排列
        return v1.score < v2.score; // 返回 true 时, v1 在前面 
    }
};

int main(int argc, char *argv[]){
    Person p1("zhangsan", 23, 95);
    Person p2("lisi", 22, 99);
    Person p3("wangwu", 21, 97);

    std::vector<Person> P = {p1, p2, p3};

    // 按照年龄降序排列
    std::sort(P.begin(), P.end(), Compare1());
    for(Person p : P) std::cout << p.name << " " << p.age << " " << p.score << std::endl;
    std::cout << "-----------" << std::endl;

    // 按照成绩升序排列
    std::sort(P.begin(), P.end(), Compare2());
    for(Person p : P) std::cout << p.name << " " << p.age << " " << p.score << std::endl;

    return 0;
}
cpp 复制代码
// 运行结果
zhangsan 23 95
lisi 22 99
wangwu 21 97
-----------
zhangsan 23 95
wangwu 21 97
lisi 22 99
相关推荐
程序员龙一22 分钟前
C++之static_cast关键字
开发语言·c++·static_cast
奶茶树33 分钟前
【C++/STL】map和multimap的使用
开发语言·c++·stl
云知谷2 小时前
【C/C++基本功】C/C++江湖风云录:void* 的江湖传说
c语言·开发语言·c++·软件工程·团队开发
ShineWinsu3 小时前
对于数据结构:堆的超详细保姆级解析—上
数据结构·c++·算法·计算机·二叉树·顺序表·
im_AMBER3 小时前
Leetcode 46
c语言·c++·笔记·学习·算法·leetcode
QX_hao3 小时前
【Go】--文件和目录的操作
开发语言·c++·golang
卡提西亚3 小时前
C++笔记-20-对象特性
开发语言·c++·笔记
三掌柜6664 小时前
C++ 零基础入门与冒泡排序深度实现
java·开发语言·c++
沐怡旸5 小时前
【穿越Effective C++】条款15:在资源管理类中提供对原始资源的访问——封装与兼容性的平衡艺术
c++·面试
利刃大大5 小时前
【高并发服务器:HTTP应用】十五、HttpRequest请求模块 && HttpResponse响应模块设计
服务器·c++·http·项目