80分 求助stl中的map使用上的一个问题

ymfhcn 2009-03-17 06:02:32
map<int,int> m;
int i = m[0];
int j = m[1];
int k = m[2];
int size = m.size();//这里size==3,可我想要的是size==0

我的本意是,只有m[0] = 100;这种情况下才给map添加数据,
如果是int i = m[0];这种情况,就不增加数据了
不知道map能不能这样干
...全文
89 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
jssz103b 2009-03-17
  • 打赏
  • 举报
回复
同感
ryfdizuo 2009-03-17
  • 打赏
  • 举报
回复
map中不会添加相同的元素.
sujiewen 2009-03-17
  • 打赏
  • 举报
回复
map[]和数组[]要区分开来,你最好用FIND去找数据哦
beyond071 2009-03-17
  • 打赏
  • 举报
回复

如果是int i = m[0];这种情况,就不增加数据了

这是什么意思,这样也能比较么
KevinYuen 2009-03-17
  • 打赏
  • 举报
回复
不要随意使用map[]这样的,最好你先find一下,看有还是没有,否则map会自动增加没有查到的key的second值,循环次数一多,map容量激增
chin_chen 2009-03-17
  • 打赏
  • 举报
回复
补充一下:
m[0]==100//时说有个key是0,然后看其value是否是100的。

m.insert(num);
这个num是个pair啊,是pair<int ,int>类型的。
chin_chen 2009-03-17
  • 打赏
  • 举报
回复
[Quote=引用楼主 ymfhcn 的帖子:]
map <int,int> m;
int i = m[0];
int j = m[1];
int k = m[2];
int size = m.size();//这里size==3,可我想要的是size==0

我的本意是,只有m[0] = 100;这种情况下才给map添加数据,
如果是int i = m[0];这种情况,就不增加数据了
不知道map能不能这样干
[/Quote]
没看懂你说了什么,
但是“m[0] = 100;这种情况下才给map添加数据”,
if(m[0]==100)
{
m.insert(num);
}是这个意思么?
Qlaiaqu 2009-03-17
  • 打赏
  • 举报
回复
确实一片混乱,但是我们的工作就是化乱为整啊。
size记录的是map中包含元素的个数。
而采用[]进行访问,是在[]填入key来获取value值,所以这里你要认识清楚
野男孩 2009-03-17
  • 打赏
  • 举报
回复
lz在想啥呢?确定自己知道map是干吗用的吗?代码跟你的本意完全是两回事,一片混乱。
jwpl190 2009-03-17
  • 打赏
  • 举报
回复
当你使用
int i = m[0];

m[0] 就添加了一个元素。
key 为 0
value 没有赋值也为0;
m[i] 就是访问以 i 为 key 在元素。没有就自动添加。
如果 只有m[0] = 100;这种情况下才给map添加数据, 那就是只能有一个key 了,
使用map 还有什么意义呢。

sagegz 2009-03-17
  • 打赏
  • 举报
回复
m[0]=100?
应该是m[0]==100的时候吧?
既然都有m[0]了,0当然就已经是map中的key了.
所以你应该先进行比较是否等于100,然后再向map中添加key.

64,682

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧