c++ set、map的四种自定义排序方法

简介: c++ set、map的四种自定义排序方法

比如对于"100","99"要进行排序

一、set的三种遍历方式

set<string> myset={"99","100"};
//set的三种遍历方式
for(string s:myset) cout<<s<<' ';
for(const string& s:myset) cout<<s<<' ';//set的值本身是不可修改的,使用引用就要加上const
for(auto it=myset.begin();it!=myset.end();it++) cout<<*it<<' ';

可以发现,上述输出为"100",“99”,因为默认采用的less,按照字典序的从小到大,因为19小,所以1放前,如果要实现"99"放“100”前面,那么就要自定义比较函数了

二、set自定义比较函数

方式一:仿函数 重载运算符()

注意要声明为const成员函数

值传递

struct cmp{
    bool operator()(string a,string b)const{
        return stoi(a)<stoi(b);
    }
};
set<string,cmp> myset={"99","100"};
class cmp{
public:
    bool operator()(string a,string b)const{
        return stoi(a)<stoi(b);
    }
};
set<string,cmp> myset={"99","100"};

引用传递

struct cmp{
    bool operator()(const string& a,const string& b)const{
        return stoi(a)<stoi(b);
    }
};
set<string,cmp> myset={"99","100"};
class cmp{
public:
    bool operator()(const string& a,const string& b)const{
        return stoi(a)<stoi(b);
    }
};
set<string,cmp> myset={"99","100"};

后面的例子中,统一用引用传递了,不再重复了

方式二:普通函数

bool cmp(const string& a,const string& b){
    return stoi(a)<stoi(b);
}
int main(){
    set<string,decltype(&cmp)> myset(cmp);
    myset={"100","99"};
}

方式三:类成员函数

类成员函数要加上static

class Solution{
public:
    static bool cmp(const string& a,const string& b){
        return stoi(a)<stoi(b);
    }
    void test(){
        set<string,decltype(&cmp)> myset(cmp);
        myset={"100","99"};
    }
};

方式四:lambda表达式

auto cmp=[](const string& a,const string& b){
        return stoi(a)<stoi(b);
    };
set<string,decltype(cmp)> myset(cmp);
myset={"100","99"};

三、multiset自定义比较函数

以lambda表达式的写法为例, 说明只需要修改set为multiset,其他都是一摸一样的

auto cmp=[](const string& a,const string& b){
    return stoi(a)<stoi(b);
};
multiset<string,decltype(cmp)> myset(cmp);
myset={"100","99","100"};

四、map自定义比较函数

仿函数 重载运算符()

struct cmp{
    bool operator()(const string& a,const string& b)const{
        return stoi(a)<stoi(b);
    }
};
map<string,int,cmp> mp;
mp={{"100",1},{"99",2}};

lambda表达式

auto cmp=[](const string& a,const string& b){
        return stoi(a)<stoi(b);
    };
map<string,int,decltype(cmp)> mp(cmp);
mp={{"100",1},{"99",2}};

c++ unordered_map4种遍历方式

五、multimap自定义比较函数

struct cmp{
    bool operator()(const string& a,const string& b)const{
        return stoi(a)<stoi(b);
    }
};
multimap<string,int,cmp> mp;
mp={{"100",1},{"99",2}};

都是一个套路,记住了set的自定义排序方法
也就等于会了set、multiset、map、multimap的自定义排序

相关文章
|
16天前
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
52 18
你对Collection中Set、List、Map理解?
|
10天前
|
存储 缓存 安全
只会“有序无序”?面试官嫌弃的List、Set、Map回答!
小米,一位热衷于技术分享的程序员,通过与朋友小林的对话,详细解析了Java面试中常见的List、Set、Map三者之间的区别,不仅涵盖了它们的基本特性,还深入探讨了各自的实现原理及应用场景,帮助面试者更好地准备相关问题。
47 20
|
26天前
|
存储 C++ 容器
【C++】map、set基本用法
本文介绍了C++ STL中的`map`和`set`两种关联容器。`map`用于存储键值对,每个键唯一;而`set`存储唯一元素,不包含值。两者均基于红黑树实现,支持高效的查找、插入和删除操作。文中详细列举了它们的构造方法、迭代器、容量检查、元素修改等常用接口,并简要对比了`map`与`set`的主要差异。此外,还介绍了允许重复元素的`multiset`和`multimap`。
30 3
【C++】map、set基本用法
|
1月前
|
存储
`map()`方法在什么场景下会比 `forEach()`方法更高效?
综上所述,当需要对数组元素进行复杂的转换并生成新数组、进行链式调用和函数式编程、处理元素之间存在明确映射关系的情况以及与其他数组方法结合使用时,`map()`方法比`forEach()`方法更高效,能够使代码更加简洁、清晰和易于维护。
57 32
WK
|
1月前
|
Python
Python中format_map()方法
在Python中,`format_map()`方法用于使用字典格式化字符串。它接受一个字典作为参数,用字典中的键值对替换字符串中的占位符。此方法适用于从字典动态获取值的场景,尤其在处理大量替换值时更为清晰和方便。
WK
79 36
|
26天前
|
存储 算法 C++
【C++】unordered_map(set)
C++中的`unordered`容器(如`std::unordered_set`、`std::unordered_map`)基于哈希表实现,提供高效的查找、插入和删除操作。哈希表通过哈希函数将元素映射到特定的“桶”中,每个桶可存储一个或多个元素,以处理哈希冲突。主要组成部分包括哈希表、哈希函数、冲突处理机制、负载因子和再散列,以及迭代器。哈希函数用于计算元素的哈希值,冲突通过开链法解决,负载因子控制哈希表的扩展。迭代器支持遍历容器中的元素。`unordered_map`和`unordered_set`的插入、查找和删除操作在理想情况下时间复杂度为O(1),但在冲突较多时可能退化为O(n)。
21 5
|
26天前
|
存储 C++ 容器
【C++】map的模拟实现
C++中的`map`是STL中的一种关联容器,存储键值对且键唯一。`map`基于红黑树实现,自动按键排序,支持动态调整、复杂数据类型、丰富的成员函数及双向迭代器。插入、查找等操作保证了对数时间复杂度,适用于需要快速查找和有序存储的场景。
22 3
|
1月前
|
存储 JavaScript 前端开发
如何选择使用`map()`方法和`forEach()`方法?
选择使用`map()`方法还是`forEach()`方法主要取决于操作的目的、是否需要返回值、代码的可读性和维护性等因素。在实际开发中,需要根据具体的业务需求和场景来灵活选择合适的方法,以实现更高效、更易读和更易维护的代码。
26 3
|
2月前
|
存储 JavaScript 前端开发
《进阶篇第8章:vuex》包括理解vuex、安装vuex、搭建vuex环境、四个map方法的使用、模块化+名命空间
《进阶篇第8章:vuex》包括理解vuex、安装vuex、搭建vuex环境、四个map方法的使用、模块化+名命空间
22 3
|
2月前
|
存储 JavaScript 前端开发
Set、Map、WeakSet 和 WeakMap 的区别
在 JavaScript 中,Set 和 Map 用于存储唯一值和键值对,支持多种操作方法,如添加、删除和检查元素。WeakSet 和 WeakMap 则存储弱引用的对象,有助于防止内存泄漏,适合特定场景使用。