map和multimap

文章详细介绍了C++中map和set的区别,map作为键值对的数据结构,基于红黑树自动排序,不允许重复键值。插入元素时,map会因键值重复而更新value,而multimap允许重复键值。同时,文章展示了map的插入、访问、遍历、查找及获取大小的方法。
摘要由CSDN通过智能技术生成

map相对于set区别,map具有键值和实值,所有元素根据键值自动排序,pair的第一个值被称为键值key,pair的第二个值被称为实值value。map也是以红黑树为底层实现机制,根据key进行排序

构造函数

#include<map>
map<int,string> m;
multimap<T1,T2> mlmap;

插入

  • 方法一

    map的key重复将无法放入,multimap则可以

    m.insert({1,"汪汪汪"});
  • 方法二

    map的key重复则更新value
    注意!!multimap不能用这种方法,因为key不唯一
    []方法访问map,如果key不存在将会自动创建

    m[2]="喵喵喵";
  • 其他方法

    m.insert(pair<int,string>(3,"咩咩咩"));
    m.insert(make_pair(4,"咕咕咕"));

遍历

for(auto it=m.begin();it!=m.end();it++)
{
	cout<<it->first<<" "<<(*it).second<<endl;
}
for(auto it:m)
{
	cout<<it.first<<" "<<it.second<<endl;
}

查找

返回迭代器,找不到返回end迭代器

auto it=m.find(2);
cout<<it->second<<endl;

大小

int size();
bool empty();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值