专栏首页刷题笔记1052 卖个萌 (20 分)

1052 卖个萌 (20 分)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/shiliang97/article/details/100125943

1052 卖个萌 (20 分)

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

[左手]([左眼][口][右眼])[右手]

现给出可选用的符号集合,请你按用户的要求输出表情。

输入格式:

输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []内。题目保证每个集合都至少有一个符号,并不超过 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.“ @\/@ ”中,你以为直接复制就可以了吗,天真 ‘\’是转义符,不能直接打印出来的,要在前面多加一个‘\’才可以,否则,呵呵,全错

cout<<"Are you kidding me? @\\/@"<<endl;//我哭了你呢??

2.输出表情的时候,要在眼睛两边加括号 3.请看题干“这里只给出符号在相应集合中的序号(从1开始)”,他说序号从1开始,你别从1开始啊,“若用户选择的序号不存在”说明 用户可以输入0,输入负数

#include<iostream>
using namespace std;
string shou[11],yan[11],kou[11];
int get(string s,string a[]){
	int k=0;
	int flag=0;
	for(int i=0;i<s.length();i++){
		if(s[i]=='['){
			flag=1;
		}if(s[i]!=' '&&s[i]!=']'&&s[i]!='['&&flag){
			a[k]+=s[i];
			 
		}
		if(s[i]==']'){
			flag=0;
			k++;
		}
	}
	return k;
}
int main(){
	string s1,s2,s3;
	getline(cin,s1);
	getline(cin,s2);
	getline(cin,s3);
	int k1=get(s1,shou);
	int k2=get(s2,yan);
	int k3=get(s3,kou);
	int n;
	cin>>n;
	int num[5];
	for(int i=0;i<n;i++){
		int flag=1;
		for(int l=0;l<5;l++){
			cin>>num[l];
			num[l]--;
			if(num[l]<0){
				flag=0;
			}
		}if(flag&&num[0]<k1&&num[4]<k1&&num[1]<k2&&num[3]<k2&&num[2]<k3){
			cout<<shou[num[0]]<<"("<<yan[num[1]]<<kou[num[2]]<<yan[num[3]]<<")"<<shou[num[4]]<<endl;
		}else{
			cout<<"Are you kidding me? @\\/@"<<endl;
		}
	}
	return 0;
}

看看人家柳婼的

1.注意了最后面的转义字符

2.用的vector 存

3.绕过了cin的空格,用的getline

#include <iostream>
#include <vector>
using namespace std;
int main() {
    vector<vector<string> > v;
    for(int i = 0; i < 3; i++) {
        string s;
        getline(cin, s);
        vector<string> row;
        int j = 0, k = 0;
        while(j < s.length()) {
            if(s[j] == '[') {
                while(k++ < s.length()) {
                    if(s[k] == ']') {
                        row.push_back(s.substr(j+1, k-j-1));
                        break;
                    }
                }
            }
            j++;
        }
        v.push_back(row);
    }
    int n;
    cin >> n;
    for(int i = 0; i < n; i++) {
        int a, b, c, d, e;
        cin >> a >> b >> c >> d >> e;
        if(a > v[0].size() || b > v[1].size() || c > v[2].size() || d > v[1].size() || e > v[0].size() || a < 1 || b < 1 || c < 1 || d < 1 || e < 1) {
            cout << "Are you kidding me? @\\/@" << endl;
            continue;
        }
        cout << v[0][a-1] << "(" << v[1][b-1] << v[2][c-1] << v[1][d-1] << ")" << v[0][e-1] << endl;
    }
    return 0;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【LeetCode第 177 场周赛】5171. 最接近的因数

    两数乘积等于 num + 1 或 num + 2 以绝对差进行度量,两数大小最接近 你可以按任意顺序返回这两个整数。

    韩旭051
  • 【未完成】7-8 最长有效括号串 (20 分)13分

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

    韩旭051
  • 【LeetCode】221. 最大正方形

    在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积。

    韩旭051
  • 1021 个位数统计 (15 分)

    给定一个 k 位整数 N=dk−110k−1+⋯+d1101+d0 (0≤di≤9, i=0,⋯,k−1, dk−1>0),请编写程序统计每种不同的个位数字出现...

    可爱见见
  • 算24

    解题思路: n个数算24,必有两个数要先算。这两个数算的结果,和剩余n-2个数,就构成了n-1个数求24的问题。枚举先算的两个数,以及这两个数的运算方式。n...

    AI那点小事
  • P1401 城市(30分,正解网络流)

    题目描述 N( )个城市,M( )条无向边,你要找T( )条从城市1到城市N的路,使得最长的边的长度最小,边不能重复用。 输入输出格式 输入格式: 第1行...

    attack
  • hdu 5249 KPI 权值线段树裸题

    用户2965768
  • 2018年全国多校算法寒假训练营练习比赛(第一场)六子冲

     棋盘上攻击方的2个棋子(2子必须相连并主动移动其中的1个)与被攻方的1个棋子皆处在一条直线上并相邻时,被攻方的这个棋子就被消灭  每次移动后判断一下,移动后...

    mathor
  • HDU 5806

    思路:尺取法!!如果已经统计过的数中有k个数是不小于m的,那么后面再加上任意数,这个区间都符合要求。想通了这一点,这道题便好做了。 一发AC

    用户7727433
  • hust Dating With Girls

    http://acm.sdibt.edu.cn:8080/judge/contest/view.action?cid=573#problem/B 题意:求最大权...

    用户1624346

扫码关注云+社区

领取腾讯云代金券