stl—map

map:

总是记不住,整理一下

 #include <map>#include <string>#include <utility>using namespace std;int main() {map<string, int> dict; // dict存放每个名字对应的班级号,初始时为空dict.insert(make_pair("Tom", 1));   // {"Tom":1}dict.insert(make_pair("Jone", 2));  // {"Tom":1, "Jone":2}dict.insert(make_pair("Mary", 1));  // {"Tom":1, "Jone":2, "Mary":1}dict.insert(make_pair("Tom", 2)); //如果新加入的键已经存在,那么再次插入这个键,插入无效。  // {"Tom":1, "Jone":2, "Mary":1}return 0;}#include <iostream>#include <map>#include <string>using namespace std;int main() {map<string, int> dict;  // dict 存放每个名字对应的班级号,初始时为空dict["Tom"] = 1;   // {"Tom":1}dict["Jone"] = 2;  // {"Tom":1, "Jone":2}dict["Mary"] = 1;  // {"Tom":1, "Jone":2, "Mary":1}cout << "Mary is in class " << dict["Mary"] << endl;cout << "Tom is in class " << dict["Tom"] << endl;if(dict.count("Mary")){cout<<"Mary is in class"<<dict["Mary"]<<endl;}else{cout<<"Mary has not in class"<<endl;}for(map<string,int>::iterator it = dict.begin();it!=dict.end();it++){cout<<it->first<<":"<<it->second<<endl;//键:值}//遍历map自动对键从小到大遍历return 0;}//二维map:左边是键,右边是值。map<int,set<string> >smap<int,map<string,int> >s//可以用来统计一个班里相同名字的人数//例子:输入班级和名字,做出相应统计:输出每个班的同学的名字,如果有重名,输出重名的人数#include <iostream>#include <map>#include <string>using namespace std;int main() {map<int,map<string,int> > info;int n;cin>>n;for(int i=0 ; i<n ; ++i){int class_id;string name;cin>>class_id>>name;info[class_id][name]++;}for(map<int,map<string,int> >::iterator it1 = info.begin();it1!=info.end();it1++){for(map<string,int>::iterator it2 = it1->second.begin();it2!=it1->second.end();it2++){cout<<"There are "<<it2->second<<" people named "<<it2->first<<" in class "<<it1->first<<endl;}}return 0;}

可以看出:
1.map是一个键和值的映射,我们创建一个map时,可以通过insert(),但是insert函数的参数必须时pair类型。pair时标准库类型,使用时候需要导入头文件utility。makepair(v1,v2)函数返回v1v2初始化过的pair。所以如果我们想插入一个键为v1,值为v2的映射,那就可以inser(makepair(v1,v2)).
创建一个map,我们也可以通过下标访问来实现。直接用[]就能访问键的值。而且我们能够在初始化之后直接通过附一个新的值,来改变键的值,这比利用insert插入要方便得多,因为insert插入过一次之后,再插入相同的键,那么这个新的插入语句是不工作的,也就是说,我们不能够通过插入一个相同的键来改变他的值。
2.常用的函数有count(),查找某个键是否被映射过。clear()函数可以清空map和其内存。如果要遍历map,还是通过迭代器,迭代器指向的元素是一个pair,first变量代表key,second变量代表value。
3.map可以进行嵌套,遍历方法类似二维数组,只不过利用了迭代器。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/560507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java integer reverse_Leetcode7 Reverse Integer Java实现及分析

首先public int reverse(intx) {int ans 0;while(x!0) {int temp x%10;x/10;ans ans*10temp;}returnans;}但是这样无法检验最终结果是否溢出。我们可以看到&#xff0c;溢出的原因是ans*10temp>MAX或ans*10temp对于正数&#xff0c;举个小点的例子&#xff0c;一个6bit的…

java swing linux_Linux下关于解决JavaSwing中文乱码的情况

前两天在linux中运行java 老是出乱码&#xff0c;很苦恼&#xff0c;后来网上找了好多解决办法。有些可行&#xff0c;有些不可行&#xff0c;今天总结一下。redhed 貌似没出现乱码 本身就jdk就支持中文红旗linux suse等都不支持&#xff0c;需要自己手工配置&#xff0c;解决…

单片机实验:外部中断按键

这是之前写的&#xff0c;一直没发。 实验内容&#xff1a; 实验大致上就是说&#xff1a;按键不按的时候&#xff0c;灯一直亮&#xff0c;按键按下的时候&#xff0c;灯不亮&#xff0c;报警器响。现在给了汇编语言&#xff0c;要改成c语言&#xff0c;并在proteus里面仿真…

java 内存泄露 书籍_java虚拟机内存溢出和泄漏实例

测试参数设置&#xff1a;1、循环调用new A()实现堆溢出&#xff0c;java.lang.OutOfMemoryError: Java heap space&#xff0c;虚拟机参数&#xff1a;-Xms1M -Xmx1M -XX:HeapDumpOnOutOfMemoryError&#xff0c;解释&#xff1a;将-Xmx和-Xms设置为一样可以避免堆自动扩展&am…

(dfs)选数

题目 从 1,2,3,⋯,30 这 30 个数中选 8 个数出来&#xff0c;使得和值为 200。问有多少种选法。 输出70. 思路 可行性剪枝&#xff1a; 要么选要么不选&#xff0c;如果选的多&#xff0c;退出&#xff0c;和超过200退出&#xff0c;选到最后一个数&#xff0c;进行判断&…

(dfs)迷宫最小步数

题目&#xff1a; 题目&#xff1a;有一个nmn mnm大小的迷宫&#xff0c;字符′S′&#x27;S&#x27;′S′表示起点&#xff0c;字符′T′&#x27;T&#x27;′T′表示终点, ′∗′&#x27; * &#x27;′∗′表示墙壁&#xff0c;字符 ′.′&#x27; . &#x2…

java读取大txt文件_Java读取具有7000万行文本的大文本文件

小编典典1)我确定速度没有差异&#xff0c;两者都在内部使用FileInputStream和缓冲2)您可以进行测量并亲自查看3)虽然没有性能优势&#xff0c;但我喜欢1.7方法try (BufferedReader br Files.newBufferedReader(Paths.get("test.txt"), StandardCharsets.UTF_8)) {f…

实现邻接表

题目 无向图&#xff0c;共有10个点&#xff0c;输入m条边。 输入&#xff1a; 10 1 2 2 4 3 4 5 6 7 9 10 1 8 9 9 5 3 7 3 8 输出&#xff1a; 1 : 2 10 2 : 1 4 3 : 4 7 8 4 : 2 3 5 : 6 9 6 : 5 7 : 9 3 8 : 9 3 9 : 7 8 5 10 : 1 代码&#xff1a; #include <iostre…

java 重复代码优化_Java代码优化

优化实践1.try{}catch(){}使用1)查询中不要使用try{}catch(){}语句2)循环中不要使用try{}catch(){}语句3)异常处理不要对于所有的异常捕获都使用Exception&#xff0c;最好是捕获对应的异常类型&#xff0c;处理日志方式&#xff1a;1、打印错误日志2、调用错误业务逻辑处理函数…

c++变量,对象

变量&#xff0c;对象 变量&#xff08;variable&#xff09;&#xff1a;提供一个具名的、可供程序操作的存储空间。 对象&#xff08;object&#xff09;&#xff1a;一块能存储数据并具有某种类型的内存空间。 在是否命名上&#xff0c;有的人把命了名的对象称为变量。在…

java 微信 回复_微信java 开发2 发送文本消息并回复

因为用的是springmvc首先看一下统一接收接口&#xff0c;dispatchWeiXinRequest发放用于区别get还是postRequestMapping(value "/dispatcher")ResponseBodypublic void dispatcher(HttpServletRequest request,HttpServletResponse response) throws ParseException…

java 06_JAVA06 数组

1.设计思路&#xff1a;首先设置长度为10的数组&#xff0c;设置Random引用对象&#xff0c;在循环中生成一个随机数存储在数组中&#xff0c;累加和&#xff0c;利用对话框输出结果。2.程序流程图&#xff1a;3.源程序代码&#xff1a;1 //2016/11/062 //随机生成10个数&#…

java service 事物_Service 事务(JdbcUtils 升级)

1. DAO 事务// 在 DAO 中处理事务真是"小菜一碟"public void xxx(){Connection con null;try{con JdbcUtils.getConnection();con.setAutoCommit(false); // 开启事务QueryRunner qr new QueryRunner();String sql ...;Object[] params ...;qr.update(con,sql,p…

c++ const限定符

const限定符 const对像一旦创建&#xff0c;其值就不能发生改变。const对象必须初始化 const int i get_size();//正确&#xff0c;运行时初始化。 const int j 1;//正确&#xff0c;编译时初始化。j 2;//错误&#xff0c;j是一个常量&#xff0c;试图对其赋值行为将发生错误…

java 8.0 sinffer_jpcap 配置方法,问题解决,模拟sniffer程序。(附JAVA程序,jar,dll包等环境)...

一、 Eclipse环境下安装与配置Jpcap相关源程序、jpcap jar包&#xff0c;dll包&#xff0c;帮助文档。1、下载安装winpcap2、jpcap官方文件中lib包下&#xff0c;有两个文件&#xff0c;jpcap.dll和jpcap.jar。jpcap.dll-->JAVA安装路径/jre1.6.0_06/bin (JRE目录)jpcap.j…

c++ 参数传递

参数传递&#xff1a; 形参&#xff08;parameter&#xff09;和实参&#xff08;argument&#xff09;&#xff1a; int num (int a, int b); int num (int a, int b){return ab; }//在函数的声明或者定义里&#xff0c;由由0个或多个形参组成的列表。int main(){int n1,m1;co…

c++定义成员函数

1.定义和声明成员函数的方式和普通函数差不多。成员函数的声明必须在类的内部&#xff0c;他的定义则即可以在类的内部也可以在类的外部。非成员函数的定义和声明都在类的外部。 struct Sales_data{std::string isbn() const { return bookNo; }double avg_price() const;std:…

java拖动图片拼图_求教,我的这个拼图程序中的移动图片的改怎么做

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼public class button extends JPanel implements MouseListener, ActionListener {/****/private static final long serialVersionUID 1L;private JButton[] button;private ImageIcon[] puzzlep;private JButton kbbutton;priva…

c++函数返回值是一个引用

函数返回值是一个引用的情况&#xff1a; 1.值是如何被返回的&#xff1a; 返回的值用于初始化调用点的一个临时量&#xff0c;该临时量就是函数调用的结果。 如果函数返回引用&#xff0c;则该引用仅是它所引对象的一个别名。 2.不能返回局部对象的引用或指针&#xff1a;…

java视频压缩 lz4_一种视频序列帧的压缩方法、解压方法及装置与流程

技术特征&#xff1a;1.一种视频序列帧的压缩方法&#xff0c;其特征在于&#xff0c;包括&#xff1a;在视频帧数据压缩时&#xff0c;对解析到的第一帧视频帧数据使用lz4算法进行压缩并保存至视频文件中&#xff1b;对之后解析到的每一帧视频帧数据都与之前一帧视频帧数据进行…