心得:
当题目说没有明确表示索引的范围,注意数组,容器的上溢和下溢
题目:
萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
[左手]([左眼][口][右眼])[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []
内。题目保证每个集合都至少有一个符号,并不超过 10 个符号;每个符号包含 1 到 4 个非空字符。
之后一行给出一个正整数 K,为用户请求的个数。随后 K 行,每行给出一个用户的符号选择,顺序为左手、左眼、口、右眼、右手——这里只给出符号在相应集合中的序号(从 1 开始),数字间以空格分隔。
输出格式:
对每个用户请求,在一行中输出生成的表情。若用户选择的序号不存在,则输出 Are you kidding me? @\/@
。
输入样例:
[╮][╭][o][~\][/~] [<][>]
[╯][╰][^][-][=][>][<][@][⊙]
[Д][▽][_][ε][^] ...
4
1 1 2 2 2
6 8 1 5 5
3 3 4 3 3
2 10 3 9 3
输出样例:
╮(╯▽╰)╭
<(@Д=)/~
o(^ε^)o
Are you kidding me? @\/@
思路:
关键是如何从一串字符串中提取符号,分割肯定是不行,
正确做法是遍历字符串,当遇到一个'[' 时开始提取,直到遇到‘]’ 结束,存放进容器中
1.提取的时候应该先把这些符号都放进一个临时字符串变量中,因为字符可能不止一个,有的是多个字符组成的符号
2.直到提取结束,再把临时字符串变量存进容器,这样方便通过索引查找
当没找到时,注意索引,不要只判断下溢出,即给的数字大于某表情集合的长度,还要注意上溢,即给的数字小于1
输出"Are you kidding me? @\/@"时,注意输出'\'反斜杠时,要转义一下,即再写一个反斜杠,就是"Are you kidding me? @\\/@"
代码:
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<string> hand;
vector<string> eye;
vector<string> mouth;
vector<vector<string>> v;
v.push_back(hand);
v.push_back(eye);
v.push_back(mouth);
for(int j=0;j<3;j++)
{
string temp;
getline(cin,temp);
for(int i=0;i<temp.size();i++)
{
int index=0;
string str="";
if(temp.at(i)=='[')
{
index=i;
while(temp.at(++index)!=']')
str+=temp.at(index);
v.at(j).push_back(str);
}
}
}
int num;
int c[5]={0};
cin>>num;
for(int i=0;i<num;i++)
{
for(int j=0;j<5;j++)
cin>>c[j];//下面很长,其实就是判断是否上溢出和下溢出
if(c[0]<1||c[0]>v.at(0).size()||c[4]<1||c[4]>v.at(0).size()||c[1]<1||c[1]>v.at(1).size()||c[3]<1||c[3]>v.at(1).size()||c[2]<1||c[2]>v.at(2).size())
{
cout<<"Are you kidding me? @\\/@"<<endl;
continue;
}
cout<<v.at(0).at(c[0]-1)<<"("<<v.at(1).at(c[1]-1)<<v.at(2).at(c[2]-1)<<v.at(1).at(c[3]-1)<<")"<<v.at(0).at(c[4]-1)<<endl;
}
return 0;
}