0

0

c++怎么自定义STL容器的比较函数_c++排序与映射自定义比较器方法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-10-21 18:47:01

|

598人浏览过

|

来源于php中文网

原创

自定义STL容器比较函数可通过函数对象、函数指针或Lambda实现,用于控制排序行为。1. std::sort支持自定义比较规则,如降序或按结构体成员排序,推荐使用const引用避免拷贝;2. set/map通过模板参数传入比较器,可定义升序、降序或复杂逻辑(如Point坐标比较);3. priority_queue默认大根堆,需自定义比较器实现小根堆,如返回a>b创建最小堆。Lambda适用于简单场景,仿函数适合复杂或复用情况。关键在于比较函数返回true时表示第一个参数应排在第二个之前,逻辑需保持一致。

c++怎么自定义stl容器的比较函数_c++排序与映射自定义比较器方法

在C++中,自定义STL容器的比较函数通常用于控制排序行为或实现特定逻辑的元素顺序。常见场景包括 std::sortstd::setstd::mapstd::priority_queue 等需要比较元素的容器或算法。可以通过函数对象(仿函数)、函数指针或Lambda表达式来实现。

1. 自定义 std::sort 的比较函数

对数组或vector等序列容器排序时,可通过传入比较函数改变默认升序规则。

例如,对整数降序排序:

#include 
#include 
#include 

bool cmp(int a, int b) {
    return a > b;  // 降序
}

int main() {
    std::vector vec = {3, 1, 4, 1, 5};
    std::sort(vec.begin(), vec.end(), cmp);
    
    for (int x : vec) std::cout << x << " ";
    // 输出: 5 4 3 1 1
}

也可以使用Lambda:

立即学习C++免费学习笔记(深入)”;

std::sort(vec.begin(), vec.end(), [](int a, int b) {
    return a > b;
});

2. 自定义类类型的排序规则

若元素是自定义结构体,需明确如何比较。

例如按学生分数排序:

struct Student {
    std::string name;
    int score;
};

std::vector students = {{"Alice", 85}, {"Bob", 90}, {"Charlie", 78}};

std::sort(students.begin(), students.end(), [](const Student& a, const Student& b) {
    return a.score > b.score;  // 分数高者在前
});

注意:参数应使用const引用避免拷贝,提高效率。

Artflow.ai
Artflow.ai

可以使用AI生成的原始角色、场景、对话,创建动画故事。

下载

3. 在 set 或 map 中使用自定义比较器

std::set 和 std::map 默认按键升序排列,若键为自定义类型或需不同顺序,需指定比较器作为模板参数。

例如,创建一个按降序排列的set:

struct greater_cmp {
    bool operator()(int a, int b) const {
        return a > b;
    }
};

std::set s = {3, 1, 4, 1, 5};
// 遍历时输出: 5 4 3 1

对于结构体作为键的情况:

struct Point {
    int x, y;
};

struct ComparePoint {
    bool operator()(const Point& a, const Point& b) const {
        if (a.x != b.x) return a.x < b.x;
        return a.y < b.y;
    }
};

std::set points;

4. 自定义 priority_queue 的比较方式

priority_queue 默认是大根堆(最大值优先),若要小根堆,需自定义比较器。

例如创建最小堆:

auto cmp = [](int a, int b) { return a > b; };
std::priority_queue, decltype(cmp)> pq(cmp);

pq.push(3); pq.push(1); pq.push(4);
// 顶部是1

或使用结构体:

struct MinHeap {
    bool operator()(int a, int b) {
        return a > b;  // 小的优先级高
    }
};
std::priority_queue, MinHeap> pq;

基本上就这些。关键是理解比较函数返回true时表示第一个参数应排在第二个之前。在排序中返回a

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

379

2023.09.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

519

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

186

2025.07.04

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

202

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

187

2025.11.08

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

369

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

563

2023.08.10

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.2万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号