/*注意1、两个字符串拼接,不要考虑三个或三个以上
2、两个字符串可多种拼接方式,因此要用sum计算成功拼接次数,只有sum==1的时候才符合条件
题目如下
#include<iostream>
#include<algorithm>
#include<vector>
#include<cstring>
#include<map>
using namespace std;
int n,m;
vector<string> s;
map<string,string>ma;
int main(void)
{
cin>>n>>m;
while(n--)
{
string a,b;
cin>>a>>b;
ma[a]=b;
s.push_back(a);
}
while(m--)
{
int sum=0;
string da,x;
cin>>x;
if(ma.count(x))
{
cout<<ma[x]<<endl;
}
else
{
for(auto i:s)
{
string bi=x.substr(0,i.size());
if(bi==i)
{
string ai=x.substr(i.size(),x.size());
if(ma.count(ai))
{
sum++;
da=ma[bi]+ma[ai];
}
}
}
if(sum==1)
cout<<da<<endl;
else
cout<<"D"<<endl;
}
}
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复