STL中map的一个知识点
问题背景
在做USACO Section 1.1 Greedy Gift Givers的时候,我最初的想法是直接用一个map来进行数据处理。但是后来产生一个让我感到疑问的地方,后来我经过测试,发现了这个被我遗忘的一个知识点,可能对于大家来说这个小知识点算是一个“常识”,但是我却没有想到,所以刻意将它记录下来加深自己的印象。
场景回顾
下面我用一个问题来重现自己的这个问题。
问题描述
在一个班级里面有N个人,他们的学号是按照他们入学报道的顺序确定的,在报道的时候确定学生的id。现在班主任想重新编排一下学号,将原来的学号逆序,也就是说之前的第一个学号现在变成最后一个学号,最后一个学号的学生现在改为第一个学号。班主任更改的方式的通过输入学生的姓名来重新改变学生的学号。
样例输入
3
aaa
bbb
ccc
aaa 2
bbb 1
ccc 0
样例输出
aaa 2
bbb 1
ccc 0
解题思路
用map进行映射,保存数据进行处理。当班主任输入姓名时,可以由map快速查找到该学生,从而改变其学号。这个方法显得有点多此一举,这是为了重现这个问题XD
解题代码
#include<cstdio>
#include<cstring>
#include<iostream>
#include<map>
using namespace std;
const int maxn = 10;
struct Person {
string name;
int id;
}p[maxn];
map<string, Person>mp;
int n;
int main() {
scanf("%d", &n);
string str;
for(int i = 0; i < n; i++) {
cin >> str;
p[i].name = str;
p[i].id = i;
mp[str] = p[i];
}
//将学号重新编排
int num;
for(int i = 0; i < n; i++) {
cin >> str >> num;
mp[str].id = num;
}
for(int i = 0; i < n; i++) {
cout << p[i].name << " " << p[i].id << endl;
}
return 0;
}
代码出错
当我将上面的代码运行之后,输入样例,发现输出是这样的:
aaa 0
bbb 1
ccc 2
为什么我明明在上述代码的注释部分进行了学号重新编排,但是最后输出却还是原来的状态呢?
后来我经过下面的代码测试才弄明白我的问题出在哪里:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<map>
using namespace std;
const int maxn = 10;
struct Person {
string name;
int id;
}p[maxn];
map<string, Person>mp;
int n;
int main() {
scanf("%d", &n);
string str;
for(int i = 0; i < n; i++) {
cin >> str;
p[i].name = str;
p[i].id = i;
mp[str] = p[i];
}
//将学号重新编排
int num;
for(int i = 0; i < n; i++) {
cin >> str >> num;
mp[str].id = num;
}
//测试输出
for(int i = 0; i < n; i++) {
cout << p[i].name << " " << p[i].id << endl;
}
cout << "================" << endl;
for(map<string, Person>::iterator it = mp.begin(); it != mp.end(); it++) {
cout << it->second.name << " " << it->second.id << endl;
}
return 0;
}
上面的代码输出如下:
aaa 0
bbb 1
ccc 2
================
aaa 2
bbb 1
ccc 0
找出问题
通过对比输出,我发现其实将p数组放入map中,只是将p数组的拷贝放入了map中,我在map中一切操作都是对这份拷贝进行的。所以最后我输出p数组的内容时是跟初始状态一样的,根本没有任何改变,因为真正的改变是在map中的那份拷贝之中。
如果我想用这个思路解决这个问题,那么我最好换一种解决方式,通过map获得p数组中元素的索引,而不是直接通过map进行更改。
代码如下:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<map>
using namespace std;
const int maxn = 10;
struct Person {
string name;
int id;
}p[maxn];
map<string, int>mp;
int n;
int main() {
scanf("%d", &n);
string str;
for(int i = 0; i < n; i++) {
cin >> str;
p[i].name = str;
p[i].id = i;
mp[str] = i;
}
int num;
for(int i = 0; i < n; i++) {
cin >> str >> num;
p[mp[str]].id = num;
}
for(int i = 0; i < n; i++) {
cout << p[i].name << " " << p[i].id << endl;
}
return 0;
}
STL中map的一个知识点的更多相关文章
- STL中map的使用
知识点 C++中map提供的是一种键值对容器,里面的数据都是成对出现的.map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的. ...
- C++ STL中Map的按Key排序和按Value排序
map是用来存放<key, value>键值对的数据结构,可以很方便快速的根据key查到相应的value.假如存储学生和其成绩(假定不存在重名,当然可以对重名加以区 分),我们用map来进 ...
- STL中map与hash_map的比较
1. map : C++的STL中map是使用树来做查找算法; 时间复杂度:O(log2N) 2. hash_map : 使用hash表来排列配对,hash表是使用关键字来计算表位置; 时间复杂度:O ...
- STL中map与hash_map容器的选择收藏
这篇文章来自我今天碰到的一个问题,一个朋友问我使用map和hash_map的效率问题,虽然我也了解一些,但是我不敢直接告诉朋友,因为我怕我说错了,通过我查询一些帖子,我这里做一个总结!内容分别来自al ...
- C++ STL中Map的相关排序操作:按Key排序和按Value排序 - 编程小径 - 博客频道 - CSDN.NET
C++ STL中Map的相关排序操作:按Key排序和按Value排序 - 编程小径 - 博客频道 - CSDN.NET C++ STL中Map的相关排序操作:按Key排序和按Value排序 分类: C ...
- C++中的STL中map用法详解(转)
原文地址: https://www.cnblogs.com/fnlingnzb-learner/p/5833051.html C++中的STL中map用法详解 Map是STL的一个关联容器,它提供 ...
- C++ STL中Map的按Key排序跟按Value排序
C++ STL中Map的按Key排序和按Value排序 map是用来存放<key, value>键值对的数据结构,可以很方便快速的根据key查到相应的value.假如存储学生和其成绩(假定 ...
- C++ STL 中 map 容器
C++ STL 中 map 容器 Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据 处理能力,由于这个特性,它 ...
- stl中map的四种插入方法总结
stl中map的四种插入方法总结方法一:pair例:map<int, string> mp;mp.insert(pair<int,string>(1,"aaaaa&q ...
随机推荐
- Domain=com.alamofire.error.serialization.response Code=-1016 "Request failed: unacceptable content-type: text/html"
2015-11-16 10:39:17.235 PullDemo[338:60b] Application windows are expected to have a root view contr ...
- Entity Framework 学习高级篇1—改善EF代码的方法(上)
本节,我们将介绍一些改善EF代码的相关方法,如NoTracking,GetObjectByKey, Include等. l MergeOption.NoTracking 当我们只需要读 ...
- Django Template模板
Django Template 你可能已经注意到我们在例子视图中返回文本的方式有点特别. 也就是说,HTML被直接硬编码在 Python 代码之中. 下面我们来调用html views def ind ...
- html 页面视图中的资源文件(css/js/image)的路径问题。
说到html 页面视图中的资源文件的路径引用问题,这个问题以前一直没去弄明白.今天,我将公司新开发的一个项目完全移植到我本地搭建的php 环境中来,遇到了这个问题,想了一下,然后也不是很困难的就把它给 ...
- 1.1 python 安装(Windows)
1.浏览器输入URL http://www.python.org/download/ https://www.python.org/downloads/release/python-2712/ Win ...
- java模式:模板模式的简单理解
1.模板模式就是用虚类作为基类将几个要执行差不多操作中相同的部分提取出来,不同的部分各自实现! 2.下面给出简单栗子: 我要进行的操作是将大象和狐狸放入冰箱,放入大象和狐狸有相同的步骤:开冰箱和关冰箱 ...
- jsp环境搭建(Windows)
1.软件准备 JDK 最新版jdk-8u45-windows-x64.exe tomcat 最新版32-bit/64-bit Windows Service Installer Eclipse IDE ...
- HDU 1698 <线段树,区间set>
题目连接 题意: 一条长为N的铜链子,每个结点的价值为1.有两种修改,l,r,z; z=2:表示把[l,r]区间内链子改为银质,价值为2. z=3:表示把[l,r]区间内链子改为金质,价值为3. 思路 ...
- iOS屏幕旋转 浅析
一.两种orientation 了解屏幕旋转首先需要区分两种orientation 1.device orientation 设备的物理方向,由类型UIDeviceOrientation表示,当前设备 ...
- sonar tomacat配置
最近在学习Sonar,配置了好几天,才搭建起来环境,为自己的学习能力感到汗颜,赶紧在此记录一下,所谓好记性不如烂笔头. 1.Sonar介绍 Sonar是一个用于代码质量管理的开源平台,用于管理Java ...