其他分享
首页 > 其他分享> > 【最详细解析】1052 卖个萌 (20分)_28行代码AC

【最详细解析】1052 卖个萌 (20分)_28行代码AC

作者:互联网

立志用更少的代码做更高效的表达


Pat乙级最优化代码+题解+分析汇总——>传送门


萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:

[左手]([左眼][口][右眼])[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。

输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []内。题目保证每个集合都至少有一个符号,并不超过 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? @/@


难点:

话不多说看代码。


代码

#include<bits/stdc++.h>
using namespace std;
int main() {
	vector<string>v[3];
	for(int j = 0; j < 3; j++) {
		string s; getline(cin, s);
		int len = s.length();
		int find1 = 0, find2 = 0;
		while(1) {
			find1 = s.find('[', find1);
			find2 = s.find(']', find2);
			if(find1 == -1 || find2 == -1) break;
			v[j].push_back(s.substr(find1+1, find2-find1-1));
			find1++; find2++; 
		}
	}
	int n; cin>>n; while(n--) {
		int a1, a2, a3, a4, a5; 
		cin >> a1 >> a2 >> a3 >> a4 >> a5;
		a1 -= 1; a2 -= 1; a3 -= 1; a4 -= 1; a5 -= 1;
		if(a1 >= v[0].size() || a2 >= v[1].size() || a3 >= v[2].size() || a4 >= v[1].size() || a5 >= v[0].size()) {
			cout << "Are you kidding me? @\\/@" << '\n';
		} else {
			cout << v[0][a1] << '(' << v[1][a2] << v[2][a3] << v[1][a4] << ')' << v[0][a5] << '\n';
		}
	} 
	return 0;
} 

耗时

在这里插入图片描述


总结

一道非常好的题, 自认为如果在考试时碰到绝对没办法拿满分。

让我们更熟练的巩固了find()和substr()嵌套vector的用法。值得思考。

标签:输出,1052,20,符号,int,卖个,size,find2,find1
来源: https://blog.csdn.net/weixin_43899069/article/details/112692166