zoukankan      html  css  js  c++  java
  • 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 #include<stdio.h>
     2 #define MAX 12
     3 char hand[MAX][30];
     4 char eye[MAX][30];
     5 char mouth[MAX][30];
     6 int get(char p[][30]);
     7 int main()
     8 {
     9     int len1,len2,len3;
    10     len1=get(hand);
    11     len2=get(eye);
    12     len3=get(mouth);
    13     int n,i;
    14     int h1,h2,m,e1,e2;
    15     scanf("%d",&n);
    16     for(i=0;i<n;i++)
    17     {
    18         scanf("%d%d%d%d%d",&h1,&e1,&m,&e2,&h2);
    19         if((h1>len1)|| (e1>len2) || (m>len3) || (e2>len2) || (h2>len1)) //选择的序号超出了上界
    20             printf("Are you kidding me? @\/@");
    21         else if((h1<1) || (e1<1) || (m<1) || (e2<1) || (h2<1))//选择的序号超出了下界
    22             printf("Are you kidding me? @\/@");
    23         else
    24             printf("%s(%s%s%s)%s",hand[h1],eye[e1],mouth[m],eye[e2],hand[h2]);
    25         printf("
    ");
    26     }
    27     return 0;
    28 }
    29 int  get(char p[][30])
    30 {
    31     int i=0,j=0, c;
    32     int count=0;
    33     int  flag=0;//是否进入[]的标志位
    34         while((c=getchar())!='
    ')
    35         {
    36                 if(c=='[')
    37                 {
    38                         flag =1;//已经进入“[”
    39                         i++;//保存下一个符号
    40                         j=0;
    41                         count++;
    42                 }
    43                 else if(c==']')
    44                 {
    45                         flag = 0;//已经退出“]”
    46                         p[i][j]=0;
    47                 }
    48                 else
    49                 {
    50                         if(flag ==1)  
    51                         p[i][j++]=c;//将[]内的字符保存进数组
    52                 }
    53         }
    54     return count;//返回字符集中符号个数
    55 }
    在这个国度中,必须不停地奔跑,才能使你保持在原地。如果想要寻求突破,就要以两倍现在速度奔跑!
  • 相关阅读:
    POJ 3683 Priest John&#39;s Busiest Day (2-SAT+输出可行解)
    Codeforces #2B The least round way(DP)
    避免死锁的银行家算法C++程序实现
    源代码编译安装MySQL5.6.12具体过程
    Android 设计模式
    Java与设计模式-适配器模式
    Java和Flex整合报错(五)
    三层架构—再思考
    怎样让DBGrid在按住Shift点鼠标的同时能将连续范围的多行选中?
    找出你的短板
  • 原文地址:https://www.cnblogs.com/yuxiaoba/p/8526326.html
Copyright © 2011-2022 走看看