zoukankan      html  css  js  c++  java
  • PAT1052---------初步了解正则表达式

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

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

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

    输入格式:

    输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []内。题目保证每个集合都至少有一个符号,并不超过 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. 读取符号
     *      - getchar() != '
    ';
     *      - 正则表达式 "%[^]]" 读取符号;
     *      - 统计符号集的长度;
     * 2. 颜文字 实际大小可能不止一个字符
     * 3. 颜文字在命令行窗口存在无法显示的情况,需要提交答案才能真正判断正确性;
     */
    #include <stdio.h>
    
    int get(char arr[][5]){
        int i = 0;//存储符号的下标
        char c; 
        while ((c = getchar()) != '
    ') {
            if (c == '[') {
                scanf("%[^]]", arr[i++]);//读入 ']' 之前的字符 
            }
        }
        return i;
    }
    int main(){
        char hand[10][5], eye[10][5], mouth[10][5];
        int cnt_hand = get(hand);
        int cnt_eye = get(eye);
        int cnt_mouth = get(mouth);
        int K;//用户请求的个数
        scanf("%d", &K);
        while (K-- > 0) {
            int lhand, leye, m, reye, rhand;
            scanf("%d %d %d %d %d", &lhand, &leye, &m, &reye, &rhand);
            if (lhand > cnt_hand || lhand < 1 || leye > cnt_eye 
                || leye < 1 || m > cnt_mouth || m < 1 || reye > cnt_eye || reye < 1 
                || rhand > cnt_hand || rhand < 1 ) {
                printf("Are you kidding me? @\/@
    ");
            } else {
                printf("%s(%s%s%s)%s
    ", hand[lhand-1], eye[leye-1], mouth[m-1], eye[reye-1], hand[rhand-1]);
            }
        } 
        return 0;
    }
  • 相关阅读:
    SP3871 GCDEX
    P2424 约数和
    P6561 [SBCOI2020] 人
    POJ
    约数之和(acwing)
    Codeforces Round #677 (Div. 3)EF
    P1516 青蛙的约会
    VJ的MNNUrank的E
    K. Birdwatching(2019-2020 ICPC Southwestern European Regional Programming Contest (SWERC 2019-20))
    友情提示,本博客仅用于博主自己复习,不适合学习者进行学习
  • 原文地址:https://www.cnblogs.com/BananaMan/p/11271460.html
Copyright © 2011-2022 走看看