PTA basic 1052 卖个萌 (20 分) c++语言实现(g++)
萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
[左手]([左眼][口][右眼])[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []
内。题目保证每个集合都至少有一个符号,并不超过 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? @\/@
测试点0 测试用例通过
测试点1 2 序号不存在的情况 (1)大于 符号数量 (2) 小等于0
解题思路
这题坑略多
1.题目中给出的字符串 Are you kidding me? @\/@
。 其中\是转义符,需要改成Are you kidding me? @\\/@
。才能正常输出一个'\'
2.题目给的序号是从1开始的, 题目中提到
"这里只给出符号在相应集合中的序号(从 1 开始).....若用户选择的序号不存在"
这里的"序号不存在"含义是 序号小于1或者序号大于对应类型(眼/口/收)给出的符号数 要同时判断小于和大于两种情况
需要注意的地方
1.前三行给出的字符串是带有多余符号和空格的字符串, 需要用getline(cin,string &s)来获取, 但是获取之后并不需要保存这个字符串, 直接摘出其中题目要求的符号字符串,存入字符串数组就可以, 在一行字符串中的符号都取出之后, 把字符串数组push_back到二维字符串数组中
2.注意题目要求的边界条件 题目提醒符号不存在时, 有大于也有小于的情况
3.vector数组在使用下标时,如果没有明确定义数组大小,可能会产生越界错误
如果要使用vector的数组下标来进行初始赋值,需要明确定义数组的初值
AC代码
#include <iostream> #include <vector> #include <string> using namespace std; int main(){ int n,number; string temp,targetString;//暂存输入或截取的字符串 string error{"Are you kidding me? @\\/@"};//这里的\ 要添加一个转义字符\才能正确输出 vector<vector<string>> symb;// 符号数组 symb[0]是手符号 symb[1]是眼符号 symb[2]是口符号 vector<string> templist;//暂存符号的数组 vector<vector<int>> list;//序号数组 vector<int> templistNum;//暂存序号的数组 for(int i=0;i<3;i++){ getline(cin,temp); int left=0,right{0},count{0}; int strSize{(int)temp.size()}; while(left<strSize){ if(temp[left]=='['){ right=left; while(right<strSize){ if(temp[right]==']'){ targetString=temp.substr(left+1,count-1);// left+1,是从left+1位置开始取字符, count-1是取值数量-1, 结果表现为去掉了两边的方括号 templist.push_back(targetString); count=0; break; } right++; count++; } } left++; } symb.push_back(templist); templist.clear();//一行符号取完之后 清空暂存符号的数组 } cin >> n; //需要初始化(n,vector<int>(5)) for(int i=0;i<n;i++){ for(int j=0;j<5;j++){ cin >> number; templistNum.push_back(number-1); } list.push_back(templistNum); templistNum.clear(); } // [左手]([左眼][口][右眼])[右手] // 手、眼、口 int h=(int)symb[0].size();//手符号数 int e=(int)symb[1].size();//眼符号数 int m=(int)symb[2].size();//口符号数 for(int i=0;i<n;i++){ int n1{list[i][0]},n2{list[i][1]},n3{list[i][2]},n4{list[i][3]},n5{list[i][4]}; if(n1>=h||n5>=h||n2>=e||n4>=e||n3>=m||n1<0||n2<0||n3<0||n4<0||n5<0){ cout << error<<endl; continue; }else{ cout <<symb[0][n1] <<"(" <<symb[1][n2] <<symb[2][n3] <<symb[1][n4] <<")" <<symb[0][n5] <<endl; } } return 0; }
第一次提交 0 通过 1 2 不通过 (需要考虑输入序号<=0的情况)
#include <iostream> #include <vector> #include <string> using namespace std; vector<string> getSymbs(string str){ vector<string> list; string temp; int indexR,indexL,nextIndexL; for(int i=0;i<10;i++){ indexL=str.find('['); if(indexR!=-1){ if(indexL!=0) { str=str.substr(indexL); indexL=0; } indexR=str.find(']'); temp=str.substr(indexL+1,indexR-1); nextIndexL=str.find('[',1); if(nextIndexL==-1)break; str=str.substr(nextIndexL); list.push_back(temp); } } return list; } int main(){ int n,temp; string error{"Are you kidding me? @\\/@"}; vector<string> strs(3);//如果要用到数组下标,就必须初始化,否则会访问越界 for(int i=0;i<3;i++){ getline(cin,strs[i]); } cin >> n; vector<vector<int>> list(n,vector<int>(5));//需要初始化(n,vector<int>(5)) vector<vector<string>> symb(3); for(int i=0;i<n;i++){ for(int j=0;j<5;j++){ cin >> temp; list[i][j]=temp-1; } } for(int i=0;i<3;i++){ symb[i]=getSymbs(strs[i]); } // [左手]([左眼][口][右眼])[右手] // 手、眼、口 int handNum=symb[0].size(); int eysNum=symb[1].size(); int mouthNum=symb[2].size(); for(int i=0;i<n;i++){ if(list[i][0]<handNum&&list[i][4]<handNum&&list[i][1]<eysNum&&list[i][3]<eysNum&&list[i][2]<mouthNum){ cout <<symb[0][list[i][0]] <<"(" <<symb[1][list[i][1]] <<symb[2][list[i][2]] <<symb[1][list[i][3]] <<")" <<symb[0][list[i][4]] <<endl; }else{ cout << error<<endl; break; } } return 0; }