C++之map find count

本文介绍了使用C++ STL中的map容器进行元素插入的方法及返回值解析,并展示了如何使用count和find成员函数来检查键的存在状态及获取其值。

map插入值 例如map<string,int>wc;

string s;

insert(pair)------>wc.insert(make_pair(s,1))

其中insert函数是有返回值的,返回什么呢?返回一个pair

其中这个pair中的first元素是map的迭代器,second是bool,判断是否插入成功

pair<map<string,int>::iterator,bool> ret=wc.insert(make_pair(s,1));

wc.count(键值)返回0或1,代表是否存在键值

wc.find(键值)返回键值对应的second值

具体代码如下

#include<iostream>
#include<string>
#include<map>
using namespace std;
int main(){
string word;
map<string,int>wc;
while(cin>>word){
pair<map<string,int>::iterator,bool> ret=wc.insert(make_pair(word,1));
if(!ret.second){
++(*(ret.first)).second;
}
}

map<string,int>::iterator iter=wc.begin();
while(iter!=wc.end()){
cout<<(*iter).first<<" "<<(*iter).second<<endl;
++iter;
}
cout<<endl;
cout<<wc.count("zhang")<<endl;
cout<<wc.find("zhang")->second<<endl;
system("pause");
return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值