1052 卖个萌 (20 分)
题目链接
算法分析和测试点
用string类型字符串变量读入一行,然后依次判断是否为表情并存储在另一个string字符串中,本题的细节有以下几点:
1.中文字符与英文字符,前者占两个字节,后者占一个字节,这就意味着如果用char类型来存储,不能输出正常的字符。
2.转义字符’\‘在“Are you kidding me? @\/@”中必须写出“\\”才能正常输出一个’\‘
3.【】的匹配问题,只有在【】之间的符号才是表情(测试点二)
4.我只开了一个str字符串数组,所以就需要一个cnt数组来存每种表情的数目,然后就可以进一步调整下标并输出读入的要求中相应数字对应的表情。(压行 )
代码实现
#include<bits/stdc++.h>
using namespace std;
string s[5];
int cnt[5];//一个集合有几个符号
int ct, t;
string str[100];
int main(){
for(int i = 1; i <= 3; ++ i){
getline(cin, s[i]);//包含空格地读入一行
bool flag = 0;
int len = s[i].size();
for(int j = 0; j < len; ++ j){
if(s[i][j] == '['){
flag = 1;
cnt[i] ++;
ct ++;
}
if(s[i][j] != '[' && s[i][j] != ']' && s[i][j] != ' ' && flag)
str[ct] += s[i][j];//只要是合法的,都加到str字符串后面
if(s[i][j] == ']')
flag = 0;
}
}
int k;
scanf("%d", &k);
int a, b, c, d, e;
for(int i = 1; i <= k; ++ i){
scanf("%d%d%d%d%d", &a, &b, &c, &d, &e);
if(!(a >= 1 && a <= cnt[1] &&
e >= 1 && e <= cnt[1] &&
b >= 1 && b <= cnt[2] &&
d >= 1 && d <= cnt[2] &&
c >= 1 && c <= cnt[3])){
puts("Are you kidding me? @\\/@");
continue;
}
b += cnt[1];
d += cnt[1];
c += (cnt[1] + cnt[2]);
cout<< str[a]<< '('<< str[b]<< str[c]<< str[d]<< ')'<< str[e]<< endl;
}
return 0;
}
总结
对于中文字符的处理,可以选择string字符串类型,而且极有可能自己的编译器不能输出相应的中文字符,一定程度上影响了自己对结果正确性的判断。