引言
在对map的使用中,由于对业务的需要,希望map中存储元素能够按照键的大小从大到小的顺序递减存储元素,但之前没有对这块进行了解,只是想当然的使用sort来对map中的元素进行排序,但是不能这样操作的。
本文记录如何对map中的元素按照键的大小从大到小进行递减的存储元素。
map的大致介绍
概述
map是C++标准容器中的一种,也是一种关联容器,用于存储键值对,内部使用红黑树实现,可以快速查找和插入。其存储的元素默认按照键的大小从小到大的递增。
场景
由于map中存储的元素默认是按照键的值从小到大的顺序进行存储的,但是业务却希望map能够按照键的值从大到小的顺序存储元素。
误区
我的第一反应是使用sort函数来对map进行排序,但是后来发现sort排序后编译器编译不通过,反复修改折腾,最后才知道sort函数要求传入的容器迭代器类型为随机访问迭代器。而只有vector,deque和array等序列容器可以通过sort排序。
示例
本例子是一个map我想把内部的元素按照键的值从大到小的顺序存储。
示例代码(方法一)
第一种方法是通过一个类,在类中实现一个仿函数,仿函数主要是实现比较键的大小,使mapd的键按照我们预期的顺序排序。下面是示例代码。
main.cpp
#include <iostream>
#include <string>
#include <map>
#include <algorithm>
using namespace std;
struct mapSort
{
bool operator() (const int& a,const int& b) const
{
return a > b;
}
};
map<int, string, mapSort> hashPair = { {1000, "M"}, {900, "CM"}, {500, "D"}, {400, "CD"},
{100, "C"}, {90, "XC"}, {50, "L"}, {40, "XL"},
{10, "X"}, {9, "IX"}, {5, "V"}, {4, "IV"},
{1, "I"} };
class Solution {
public:
void printPairs()
{
for (const auto& var:hashPair)
{
cout << "key:" << var.first << "value:" << var.second << endl;
}
cout << "==========================" << endl;
}
Solution()
{
printPairs();
}
string intToRoman(int num) {
string strValue;
for (const auto& /*[value, symble]*/var : hashPair) {
int value = var.first;
string symble = var.second;
while (num >= value) {
num -= value;
strValue += symble;
}
if (num == 0) {
break;
}
}
return strValue;
}
};
int main()
{
Solution obj;
// 3 58 1994
cout<<"input 3,and ouput :"<<obj.intToRoman(3)<<endl;
cout << "input 58,and ouput :" << obj.intToRoman(58) << endl;
cout << "input 1994,and ouput :" << obj.intToRoman(1994) << endl;
std::cout << "Hello World!\n";
}
上述代码中,map<int,string>的键为int,若是按照键的值从大到小的顺序存储,需要定义个一个类或者结构体,在其中写一个仿函数bool operator() (const int& a,const int& b) const,通过这个仿函数来实现容器的键的比较,使其按照键的值从大到小的顺序的存储。定义map的时候,需要在键值类型的后面加上该类的名称,map<int, string, mapSort>其中mapSort就是仿函数实现键排序的类。这样map中的元素就可以按照键的值从大到小进行排序了。
运行结果
示例代码二(方法二)
第二种方法是定义一个函数,该函数与上述的仿函数功能一致,就是使map的键按照期望的顺序从大到小排序,然后将这个函数定义为一个函数指针,最终在定义map的时候,将函数指针座位参数传入。不过map的初始化就要放在后面单独进行了。
#include <iostream>
#include <string>
#include <map>
#include <algorithm>
using namespace std;
bool compare_map(const int& a, const int& b)
{
return a < b;
}
bool(*fun)(const int&, const int&) = compare_map;
map<int, string, bool(*)(const int&, const int&)> hashPair(fun);
class Solution {
public:
void printPairs()
{
for (const auto& var:hashPair)
{
cout << "key:" << var.first << "value:" << var.second << endl;
}
cout << "==========================" << endl;
}
Solution()
{
hashPair[1000] = "M";
hashPair[900] = "CM";
...//这里省略部分插入操作,实则需要写上
hashPair[1] = "I";
printPairs();
}
string intToRoman(int num) {
string strValue;
for (const auto& /*[value, symble]*/var : hashPair) {
int value = var.first;
string symble = var.second;
while (num >= value) {
num -= value;
strValue += symble;
}
if (num == 0) {
break;
}
}
return strValue;
}
};
int main()
{
Solution obj;
// 3 58 1994
cout<<"input 3,and ouput :"<<obj.intToRoman(3)<<endl;
cout << "input 58,and ouput :" << obj.intToRoman(58) << endl;
cout << "input 1994,and ouput :" << obj.intToRoman(1994) << endl;
std::cout << "Hello World!\n";
}
bool compare_map(const int& a, const int& b)是比较函数,实现将map的键按照从大到小的顺序进行比较,后面定义了函数指针,map定义的时候指明了传入的函数指针,最后插入元素,被插入的元素会按照从大到小的顺序存储。文章来源:https://www.toymoban.com/news/detail-797519.html
运行结果
以上可以参考博文:
https://blog.csdn.net/weixin_42686879/article/details/117092701文章来源地址https://www.toymoban.com/news/detail-797519.html
到了这里,关于C++中map按照从大到小的顺序存储元素的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!