在C中,map是典型的关联容器或者叫映射容器(associative container),其中的每一个元素都是由key-value这样成对出现的内容组成的,比如学号和学生之类具有一一对应关系的情形,学号可以作为key,学生对象可以作为key所对应的value。很显然这种情况下的key只
在C++中,map是典型的关联容器或者叫映射容器(associative container),其中的每一个元素都是由key-value这样成对出现的内容组成的,比如学号和学生之类具有一一对应关系的情形,学号可以作为key,学生对象可以作为key所对应的value。很显然这种情况下的key只有一个值,但是,在实际工作中,我们可能会经常需要使用多个值组合起来作为key的情况,比如我们要按照学生的视力和身高进行排序,以决定学生的座位排在前面还是后面,而且还是假定要用map来解决这样的问题(当然,这样的问题有很多其它的解决办法),那应该怎么办呢?
(1) 单值作为key的情形
我们知道map在缺省状态下,其数据是按照key的升序进行排列的。假定我们有一个Student类,声明如下:
[cpp] view plaincopy
- class Student
- {
- private:
- int id; // 学号
- string name; // 姓名
- float eyesight; // 视力
- float height; // 身高
- float chinese; // 语文成绩
- float english; // 英文成绩
- float math; // 数学成绩
- public:
- Student(int id, string name,floateyesight, float height,float chinese, float english,float math)
- {
- this->id = id;
- this->name = name;
- this->eyesight = eyesight;
- this->height = height;
- this->chinese = chinese;
- this->english = english;
- this->math = math;
- }
- int get_id()
- {
- return id;
- }
- string get_name()
- {
- return name;
- }
- float get_eyesight()
- {
- return eyesight;
- }
- float get_height()
- {
- return height;
- }
- float get_chinese()
- {
- return chinese;
- }
- float get_english()
- {
- return english;
- }
- float get_math()
- {
- return math;
- }
- };
那么下面的程序:
[cpp] view plaincopy
- int main(int argc,char**argv)
- {
- mapint, Student> stu_map; // int作为key的类型,Student作为value的类型
- stu_map.insert(make_pair(4,Student(4, "Dudley",1.1f, 170.2f, 90.5f, 89.5f, 93.0)));
- stu_map.insert(make_pair(3,Student(3, "Chris", 1.1f, 163.4f, 93.5f,90.0f, 83.5f)));
- stu_map.insert(make_pair(2,Student(2, "Bob", 1.5f, 166.6f, 86.0f,98.5f, 85.0f)));
- stu_map.insert(make_pair(1,Student(1, "Andrew", 1.5f, 173.2f, 98.5f,100.0f, 100.f)));
- mapint, Student>::iterator iter;
- for(iter = stu_map.begin(); iter != stu_map.end();++iter)
- {
- coutfirst "\t"second.get_name()
- }
- return 0;
- }
就会按照学号的升序给出输出:
1 Andrew
2 Bob
3 Chris
4 Dudley
这是缺省的情形,如果要将学生的姓名按照学号的降序输出,那么仅需将上面main函数中的
mapint,Student> stu_map;改为
mapint,Student, greaterint> > stu_map;
以及
mapint,Student>::iterator iter;改为
mapint,Student, greaterint> >::iteratoriter;
即可。
其实,mapint,Student> stu_map;这是一种缺省的情况,它和
mapint,Student, lessint> > stu_map;是一样的。
(2) 多值组合作为key的情形
现在,我们来看看多个值组合起来作为key的情况,为此,我们需要为key定义一个类,如下:
[cpp] view plaincopy
- class key
- {
- public:
- float eyesight;
- float height;
- key(float x, floaty):eyesight(x), height(y)
- {
- }
- friend bool operator const key&);
- };
- bool operator const key& key2)
- {
- // 按eyesight升序 + height升序排列
- if(key1.eyesight != key2.eyesight)
- return (key1.eyesight
- else
- return (key1.height
- // 按eyesight降序 + height降序排列
- //if(key1.eyesight != key2.eyesight)
- // return(key1.eyesight > key2.eyesight);
- //else
- // return(key1.height > key2.height);
- // 按eyesight升序 + height降序排列
- //if(key1.eyesight != key2.eyesight)
- // return(key1.eyesight
- //else
- // return(key1.height > key2.height);
- // 按eyesight降序 + height升序排列
- //if(key1.eyesight != key2.eyesight)
- // return(key1.eyesight > key2.eyesight);
- //else
- // return(key1.height
- }
再修改main函数如下:
[cpp] view plaincopy
- int main(int argc,char**argv)
- {
-
map
stu_map; - Studentstu4(4, "Dudley",1.1f, 170.2f, 90.5f, 89.5f, 93.0);
- Studentstu3(3, "Chris", 1.1f, 163.4f, 93.5f,90.0f, 83.5f);
- Studentstu2(2, "Bob", 1.5f, 166.6f, 86.0f,98.5f, 85.0f);
- Studentstu1(1, "Andrew", 1.5f, 173.2f, 98.5f,100.0f, 100.f);
- stu_map.insert(make_pair(key(stu4.get_eyesight(),stu4.get_height()), stu4));
- stu_map.insert(make_pair(key(stu3.get_eyesight(),stu3.get_height()), stu3));
- stu_map.insert(make_pair(key(stu2.get_eyesight(),stu2.get_height()), stu2));
- stu_map.insert(make_pair(key(stu1.get_eyesight(),stu1.get_height()), stu1));
-
map
::iterator iter; - for(iter = stu_map.begin(); iter != stu_map.end();++iter)
- {
- coutfirst.eyesight "\t"first.height "\t" second.get_id()"\t" second.get_name()
- }
- return 0;
- }
那么输出结果为:
1.1 163.4 3 Chris
1.1 170.2 4 Dudley
1.5 166.6 2 Bob
1.5 173.2 1 Andrew
从上面的输出,我们可以很明显地看到,是按照视力升序和升高升序输出的,另外三种可能的排序情况,也在类key的操作符“
(3)结论
1.通常我们不用STL algorithm中的sort函数,来对一个map进行排序,而对vector的元素进行排序则可以很方面地使用sort函数;
2.多值组合作为key的情况,需要我们自己定义一个key类,并在该类中重载操作符“
附两个值作为key的情况之完整的实验代码如下:
[cpp] view plaincopy
-
#include
- #include
-
#include
- using namespace std;
- class key
- {
- public:
- float eyesight;
- float height;
- key(float x, floaty):eyesight(x), height(y)
- {
- }
- friend bool operator const key&);
- };
- bool operator const key& key2)
- {
- // 按eyesight升序 + height升序排列
- if(key1.eyesight != key2.eyesight)
- return (key1.eyesight
- else
- return (key1.height
- // 按eyesight降序 + height降序排列
- //if(key1.eyesight != key2.eyesight)
- // return(key1.eyesight > key2.eyesight);
- //else
- // return(key1.height > key2.height);
- // 按eyesight升序 + height降序排列
- //if(key1.eyesight != key2.eyesight)
- // return(key1.eyesight
- //else
- // return(key1.height > key2.height);
- // 按eyesight降序 + height升序排列
- //if(key1.eyesight != key2.eyesight)
- // return(key1.eyesight > key2.eyesight);
- //else
- // return(key1.height
- }
- class Student
- {
- private:
- int id; //学号
- string name; // 姓名
- float eyesight; //视力
- float height; //身高
- float chinese; //语文成绩
- float english; //英文成绩
- float math; //数学成绩
- public:
- Student(int id, string name,floateyesight,float height,float chinese,float english,float math)
- {
- this->id = id;
- this->name = name;
- this->eyesight = eyesight;
- this->height = height;
- this->chinese = chinese;
- this->english = english;
- this->math = math;
- }
- int get_id()
- {
- return id;
- }
- string get_name()
- {
- return name;
- }
- float get_eyesight()
- {
- return eyesight;
- }
- float get_height()
- {
- return height;
- }
- float get_chinese()
- {
- return chinese;
- }
- float get_english()
- {
- return english;
- }
- float get_math()
- {
- return math;
- }
- };
- int main(int argc,char**argv)
- {
-
map
stu_map; - Studentstu4(4, "Dudley",1.1f, 170.2f, 90.5f, 89.5f, 93.0);
- Studentstu3(3, "Chris", 1.1f, 163.4f, 93.5f,90.0f, 83.5f);
- Studentstu2(2, "Bob", 1.5f, 166.6f, 86.0f,98.5f, 85.0f);
- Studentstu1(1, "Andrew", 1.5f, 173.2f, 98.5f,100.0f, 100.f);
- stu_map.insert(make_pair(key(stu4.get_eyesight(),stu4.get_height()), stu4));
- stu_map.insert(make_pair(key(stu3.get_eyesight(),stu3.get_height()), stu3));
- stu_map.insert(make_pair(key(stu2.get_eyesight(),stu2.get_height()), stu2));
- stu_map.insert(make_pair(key(stu1.get_eyesight(),stu1.get_height()), stu1));
-
map
::iterator iter; - for(iter = stu_map.begin(); iter != stu_map.end();++iter)
- {
- coutfirst.eyesight "\t"first.height "\t" second.get_id()"\t" second.get_name()
- }
- return 0;
- }

SQL中的Identity是什么,需要具体代码示例在SQL中,Identity是一种用于生成自增数字的特殊数据类型,它常用于唯一标识表中的每一行数据。Identity列通常与主键列配合使用,可以确保每条记录都有一个独一无二的标识符。本文将详细介绍Identity的使用方式以及一些实际的代码示例。Identity的基本使用方式在创建表时,可以使用Identit

一、功能概览键空间通知使得客户端可以通过订阅频道或模式,来接收那些以某种方式改动了Rediskey变化的事件。所有修改key键的命令。所有接收到LPUSHkeyvalue[value…]命令的键。db数据库中所有已过期的键。事件通过Redis的订阅与发布功能(pub/sub)来进行分发,因此所有支持订阅与发布功能的客户端都可以在无须做任何修改的情况下,直接使用键空间通知功能。因为Redis目前的订阅与发布功能采取的是发送即忘(fireandforget)策略,所以如果你的程

在拼图中选择图片和模板后保存即可。教程适用型号:iPhone13系统:iOS15.3版本:美图秀秀9.5.70&&天天P图6.5.4解析1首先进入美图秀秀的首页,找到并点击拼图。2跳转进入相册页面,选择需要合成的图片后,点击开始拼图。3选择拼图模板后,点击页面右上角的钩形图标即可。补充:天天P图如何拼接图片1首先进入天天P图首页中,找到并点击故事拼图。2待页面跳转,勾选合适的图片后,点击右下方的开始拼图。3选择喜欢的拼图模板后,点击页面右上角的保存图标即可。总结/注意事项一次拼图只能选择1至9张

An unpatchable Yubico two-factor authentication key vulnerability has broken the security of most Yubikey 5, Security Key, and YubiHSM 2FA devices. The Feitian A22 JavaCard and other devices using Infineon SLB96xx series TPMs are also vulnerable.All

遇到的问题:在开发过程中,会遇到要批量删除某种规则的key,例如login_logID(ID为变量),现在需要删除"login_log*"这一类的数据,但是redis本身只有批量查询一类key值的命令keys,但是没有批量删除某一个类的命令。解决办法:先查询,在删除,使用xargs传参(xargs可以将管道或标准输入(stdin)数据转换成命令行参数),先执行查询语句,在将查询出来的key值,当初del的参数去删除。redis-cliKEYSkey*(查找条件)|xargsr

在我的世界中,道具的合成是一项重要的任务。为了获得绿色染料,玩家需要准备一些特定的材料进行合成。下面是合成绿色染料的方法。我的世界绿色染料合成方法1、制作工作台:采集木材徒手制作工作台,放置地面待用。2、解锁熔炉:通过工作台制作熔炉,点击熔炉打开制作界面。3、合成仙人掌绿:将采集来的仙人掌方块放入熔炉,添加燃料得到仙人掌绿。4、分解骨粉:将骨头放入工作台制作界面,分解为骨粉。5、制作绿色染料:将1份骨粉和1份仙人掌绿放入工作台,制作绿色染料。

使用STL函数对象可提高可重用性,包含以下步骤:定义函数对象接口(创建类并继承自std::unary_function或std::binary_function)重载operator()以定义函数行为在重载的operator()中实现所需的功能通过STL算法(如std::transform)使用函数对象

C++STL哈希冲突的处理方式有:链地址法:使用链表存储冲突元素,适用性好。开放寻址法:在桶中查找可用位置存储元素,子方法有:线性探测:按顺序查找下一个可用位置。二次探测:以二次方形式跳过位置进行查找。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Chinese version
Chinese version, very easy to use

WebStorm Mac version
Useful JavaScript development tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

SublimeText3 Linux new version
SublimeText3 Linux latest version

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
