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;
}