C++的map用法
图,自动建立表示关键字和键值(key - value)之间的对应关系,两者可以是任何数据类型,key唯一并且自动排序,value不唯一。
1.头文件#include<map>
2.map<string,int>mp; //例如这个声明,表示字符串和数字的关系,string和int可以换成别的数据类型
3.clear() 清空操作
4.begin() 返回容器的第一个对应关系的地址
5.end() 返回容器的最后一个对应关系的地址
6.max_size() 返回容器的能存储的对应关系个数,不同数据类型不同,一般用不上
7.size() 返回容器的关系个数
8.map赋值
关系自动建立,形式类似数组,比如:
map<int,int>mp1;
	map<string,int>mp2;
	map<double,int>mp3;
	mp1[5]=10;
	mp2["sb"]=2;
	mp3[3.66]=1000;
如果此时mp1[5]=15,那么key=5的value10会被15覆盖
也可以用插入函数insert(),插入相同key不同value时不会被覆盖,不常用
9.遍历,用迭代器遍历,it访问的key用it->first,访问value用it->second
10.erase(key) 删除关键字key所指的键值
11.count(a) 查找key=a是否存在,存在则返回1,否则返回0
题目应用:(NYOJ95)
描述
所谓众数,就是对于给定的含有N个元素的多重集合,每个元素在S中出现次数最多的成为该元素的重数,
多重集合S重的重数最大的元素成为众数。例如:S={1,2,2,2,3,5},则多重集S的众数是2,其重数为3。
现在你的任务是:对于给定的由m个自然数组成的多重集S,计算出S的众数及其重数。
- 输入
- 第一行为n,表示测试数据组数。(n<30)
 每组测试的第一行是一个整数m,表示多重集S中元素的个数为m
 接下来的一行中给出m(m<100)个不大于10万的自然数
 (不会出现不同元素出现的次数相同的情况,如:S={11,11,22,22,33,33})。
- 输出
- 每组测试数据输出一行,包含两个数,第一个是众数,第二个是其重数,中间以空格隔开。
- 样例输入
- 
1 
 6
 1 2 2 2 3 5
- 样例输出
- 2 3
- AC代码:
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<map>
using namespace std;
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int m,x;
scanf("%d",&m);
map<int,int>mp;
mp.clear();
while(m--)
{
scanf("%d",&x);
mp[x]++;
}
int ans1,ans2=;
for(map<int,int>::iterator it=mp.begin();it!=mp.end();it++)
{
if(it->second>ans2)
{
ans1=it->first;
ans2=it->second;
}
}
printf("%d %d\n",ans1,ans2);
}
return ;
}
C++的map用法的更多相关文章
- Collection List Set和Map用法与区别
		labels:Collection List Set和Map用法与区别 java 散列表 集合 Collection 接 口的接口 对 象的集合 ├ List ... 
- ES6中Set 和 Map用法
		JS中Set与Map用法 一.Set 1.基本用法 ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set 本身是一个构造函数,用来生成 Set 数据结构. ... 
- sort函数(cmp)、map用法---------------Tju_Oj_2312Help Me with the Game
		这道题里主要学习了sort函数.sort的cmp函数写法.C++的map用法(其实和数组一样) Your task is to read a picture of a chessboard posit ... 
- C++中的STL中map用法详解(转)
		原文地址: https://www.cnblogs.com/fnlingnzb-learner/p/5833051.html C++中的STL中map用法详解 Map是STL的一个关联容器,它提供 ... 
- C++:map用法及元素的默认值
		C++:map用法 一.map基本用法 键值对 第一个参数为键的类型,第二个参数为值的类型. 源代码 #include <iostream> #include <string> ... 
- c++ STL map 用法
		map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据 处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时 ... 
- std::map用法
		STL是标准C++系统的一组模板类,使用STL模板类最大的好处就是在各种C++编译器上都通用. 在STL模板类中,用于线性数据存储管理的类主要有vector, list, map 等等.本文主要 ... 
- STL map 用法
		首先make_pair Pairs C++标准程序库中凡是"必须返回两个值"的函数, 也都会利用pair对象 class pair可以将两个值视为一个单元.容器类别map和mul ... 
- map用法详解
		转自:http://www.kuqin.com/cpluspluslib/20071231/3265.html Map是 STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在 ... 
- UVA11995【I can guess the data structrue!!】【水】+UVA11991【map用法】
		先看UVA11995 两份代码一份直接用C写的,一份用STL写的 #include <iostream> #include <stdio.h> #include <str ... 
随机推荐
- 单词uranolite陨石uranolite英语
			陨石(uranolite)是指来自地球以外太阳系其他天体的碎片,绝大多数来自位于火星和木星之间的小行星,少数来自月球(40块)和火星(40块).全世界已收集到4万多块陨石样品,石陨石主要成分是硅酸盐. ... 
- docker入门实例(转载)
			1.Docker 是什么?Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux 或 Windows 机器上( 摘自百度 ) ... 
- Docker-Compose通过文件声明默认的环境变量
			写文目的 在写本文之前,我在做一个docker-compose项目,这里需要在docker-compose.yml配置中引用到宿主机的ip,然而docker-compose并没有命令行一个输入的选项, ... 
- k8s部署nacos之二 nfs
			1.在linux服务器下载nacos 首先安装git命令 yum install git git clone https://github.com/nacos-group/nacos-k8s.git ... 
- Google大数据三篇著名论文中文版
			Google File System中文版 Google MapReduce中文版 Google Bigtable中文版 
- Bootstrap:UI开发平台 sdk
			Bootstrap:UI开发平台 Bootstrap是一个易用.优雅.灵活.可扩展的前端工具包,里面包含了丰富的Web组件,包括布局.栅格.表格.表单.导航.按钮.进度条.媒体对象等,基于这些组件,可 ... 
- ML学习笔记之Jupyter Notebook各种使用方法
			0x00 概述 Jupyter Notebook安装的官方网站 安装Jupyter Notebook的先决条件:已经安装了python(python 2.7 或者是python3) 具体的安装方法: ... 
- centos lnmp一键安装
			安装 系统需求: 需要2 GB硬盘剩余空间 128M以上内存,OpenVZ的建议192MB以上(小内存请勿使用64位系统) Linux下区分大小写,输入命令时请注意! 安装步骤: 1.使用putty或 ... 
- php curl 转为 x-www-form-urlencoded 方式的坑
			网上转变的方法基本都是写添加下面这句: curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-fo ... 
- JDK8 stream用法
			forEach举例 public static void main(String[] args) { // TODO Auto-generated method stub List<Person ... 
