思路:string类真是个好东西啊,可惜以前学的都忘了,以前也没整理博客。。所以就只能用一点最常用的了。就是正常按行读入,按题意模拟。我写的有点复杂了其实,网上应该有更简单的,没办法,那些函数都忘了,就只能嗯模拟了qaq
代码:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<map>
#include<vector>
#include<sstream>
using namespace std;
const int N = 105;
typedef long long ll;
string s[N],var[N];
int m,n;
string finds(int &i,string s)
{
string ans;
while(s[i]!=' ')
ans+=s[i++];
return ans;
}
int main()
{
map<string,string> mp;
cin>>m>>n;
getchar();
for(int i=0;i<m;i++)
getline(cin,s[i]);
for(int i=0;i<n;i++)
{
getline(cin,var[i]);
istringstream str(var[i]); //把string按空格分开,头文件对应上方最后一个
string tem;
str>>tem;
mp[tem]=var[i].substr(tem.size()+2,var[i].size()-tem.size()-3);
}
for(int i=0;i<m;i++)
{
string tem=s[i],ss;
if(tem.find("{{")==EOF) //没有查找到
{
cout<<tem<<endl;continue;
}
for(int i=0;i<tem.size();i++)
{
if(tem[i]=='{'&&tem[i+1]=='{')
{
i+=3;
ss=finds(i,tem);
cout<<mp[ss];
i+=2;
}
else cout<<tem[i];
}
cout<<endl;
}
return 0;
}