1052. 卖个萌 (20)-PAT乙级真题

本文介绍了一款萌萌哒表情符号生成器的设计与实现。该生成器可以根据用户的选择,从预设的手势、眼睛和嘴巴符号集中组合出各式各样的表情符号。通过使用C++编程语言和标准库中的向量容器,该程序能够灵活地处理不同数量的符号集合,为用户提供丰富的表情创作体验。

萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
[左手]([左眼][口][右眼])[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。

输入格式

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

分析:

因为不知道一行有多少个表情,所以用一个string类型的不定长二维数组vector存储表情包,以及可以调用v.size()顺便解决不知道一行有多少个表情的问题~

不定长数组共三行,分别对应输入用例的三行~只不过在存储如数组之前把它们的方括号去掉在存储~这里可以用string的substr方法实现~然后根据输入的数字序号输出对应的表情~耶耶耶能从这道题里面复习好多知识点呢~~

注意:

1.“Are you kidding me? @\/@”的’\’是转义字符,想要输出’\’就要用’\\’表示~

2.第一个测试点里面包含了空格,所以用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;
}

### 关于PAT乙级真题1010的题解 PAT乙级真题1010的题目名称为“一元多项式求导”。该题要求实现一个程序,对输入的一元多项式进行求导操作,并输出结果[^3]。 #### 题目描述 给定一个一元多项式,按照特定格式对其进行求导并输出结果。输入多项式的格式为一系列项,每一项由系数和指数组成,中间用空格分隔。例如,输入 `3 2` 表示 \(3x^2\),输出应为 `6 1`,表示 \(6x^1\)。 #### 题解思路 为了实现这一功能,可以按照以下逻辑编写代码: - 首先读取输入数据,将多项式的每一项提取出来。 - 对于每一项,计算其导数:将系数乘以指数作为新系数,指数减一作为新指数。 - 特别注意,如果某一项的指数为零,则该项求导后为零,无需输出。 - 最后将所有非零项按顺序输出。 以下是使用Java语言实现的一个示例代码: ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); while (scanner.hasNext()) { int a = scanner.nextInt(); // 系数 int b = scanner.nextInt(); // 指数 if (b > 0) { System.out.print(a * b + " " + (b - 1)); if (scanner.hasNext()) { System.out.print(" "); } } } scanner.close(); } } ``` 上述代码实现了对输入多项式的逐项求导,并正确处理了指数为零的情况[^4]。 #### 注意事项 在解答此题时,需要注意以下几点: - 输入可能包含多个项,需逐一处理。 - 如果所有项的指数均为零,则最终输出应为空。 - 输出格式必须严格符合题目要求,避免多余的空格或换行。 ###
评论 18
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值