本文共 713 字,大约阅读时间需要 2 分钟。
1、需要加的头文件
#include<map>
2、定义(例如将字符串转换成int)
map<string,int> mp;
string需要加上头文件#include<string>
注意一定要加上mp.clear();
int k=0;
scanf("%s",str);
mp[str]=k++;
如果要输入另一个字符串tmp,判断之前有没有存过
if(mp.find(tmp)==mp.end()) mp[tmp]=k++;
#include<stdio.h> #include<string.h> #include<string> #include<map> using namespace std; map<string,int> mp; char str[100],a[100]; int main() { int n; scanf("%d",&n); int k=1; for(int i=0; i<n; i++) { scanf("%s",str); mp[str]=k++; if(mp.find(str)==mp.end()) mp[str]=k++; } //查找某个字符串在map中对应的整形,如果存在就返回当时存的k值,不存在返回0 while( scanf("%s",a)!=EOF) { printf("%d\n",mp[a]); } //插入元素,查询name的对应值时,map会返回10 mp.insert(pair<string,int>("name",10)); //插入元素还可以用 char b[100];mp[b]=11; 或者是mp["name"]=10; return 0; }
转载地址:http://rhddi.baihongyu.com/