一开始90分是因为 str.find('}')
我是搜索单个字符,然后索引+-代表最终位置
这样的话,break条件容易写错
所以改成 str.find(“}}”)
这样如果 index=-1直接break就行
#include<iostream>
#include<string>
#include<vector>
#include<unordered_map>
#include<algorithm>
using namespace std;
int n,m;
int main(){
cin>>n>>m;
vector<string> v(n);
unordered_map<string,string> m1;
getchar();
for(int i=0;i<n;i++){
getline(cin,v[i]);
}
for(int i=0;i<m;i++){
string s;
string key="",value="";
cin>>key;
getline(cin,s);
value=s.substr(2,s.size()-3);
m1["{{ "+key+" }}"]=value;
}
for(int i=0;i<v.size();i++){
int index=0;
while(1){
int be=v[i].find("{{",index);
int end=v[i].find("}}",index);
if(be==-1 || end==-1 )
break;
end++;
string k=v[i].substr(be,end-be+1);
v[i].replace(be,end-be+1,m1.count(k)?m1[k]:"");
index=be+m1.count(k)?m1[k].size():0;
}
cout<<v[i]<<endl;
}
return 0;
}