文章

35

粉丝

134

获赞

55

访问

25.3k

头像
魔咒词典 题解:map建立双向映射
P1339 浙江大学机试题
发布于2024年1月20日 17:57
阅读数 637

#include <bits/stdc++.h>
using namespace std;
int main(){
	map<string ,string>mp;
	int n;
	while(true){
		char line[100];
		gets(line);//读取一行 
		string s1 = line;
		if(s1=="@END@")	 break;
		string word = s1.substr(0,s1.find(']')+1);//截取从0开始到 s1.find(']')+1这么长的子串 
		string info = s1.substr(s1.find(']')+2);//截取从s1.find(']')+2下标开始一直到结尾 
		mp[word] =  info;
		mp[info] =  word;//双向建立映射 
		
	}
	cin>>n;
	getchar();//注意要加这句处理换行 
	for(int i=0;i<n;i++){
		char line[100];
		gets(line);//读取一行 
		string s = line;
		if(mp.find(s)!=mp.end()){
			if(s[0]=='[') cout<<mp[s]<<endl;
			else cout<<mp[s].substr(1,mp[s].size()-2)<<endl;
		}else{
			cout<<"what?"<<endl;
		}
	}
	
	return 0;
	
}

 

登录查看完整内容


登录后发布评论

暂无评论,来抢沙发