苦力怕君


私信TA

用户名:uq_61490095696

访问量:1707

签 名:

等  级
排  名 25235
经  验 535
参赛次数 0
文章发表 2
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

救救我吧!

TA的其他文章

解题思路:


1、先用二维数组 f[26][5]进行摩尔斯密码的存放;

2、一次读入整行字符串 s[],再进行后续解析;

3、用 c[] 存入单个密码,再进行判断是否是具体哪一个密码;

4、通过 i 控制一个个字符读入,碰到 ‘|’结束,表示,单个密码已存入;

5、用 j 对应二维数组中第 j 个密码,用 'a'+j 进行 ASCII 码输出。


参考代码:

【注释很详细,看不懂的评论区讨论】

#include<stdio.h>
#include<string.h>
int main()
{
    char f[26][5]={"*-","-***","-*-*","-**","*","**-*","--*","****","**","*---","-*-","*-**",
    "--","-*","---","*--*","--*-","*-*","***","-","**-","***-","*--","-**-","-*--","--**"};
    char s[10000];//输入摩尔斯密码
    char c[5];//对密码进行处理 
    int i=0,j,k=0; 
    gets(s);
    while(1)
    {
        if(s[i]=='|' || s[i]=='\0')//进行单个密码结束判断
        {
            c[k]='\0';//'\0'字符串结束标志
            k=0;//k表示覆盖掉'|' 
            for(j=0;j<26;j++)
            {
                if(strlen(c)==strlen(f[j]))//码长度相等,进行进一步判断 
                {
                    if(strcmp(c,f[j])==0)//判断读入的单个密码是否与数组中对应 
                    {
                        printf("%c",'a'+j);//ASCII码,字符'a'加一个整数,则偏移为对应字符 
                        break;
                    }
                } 
            }
        }
        else
            c[k++]=s[i];//c[k++]不断读入新的字符 直到单个密码结束
        if(s[i]=='\0')
            break;//整体结束 
        i++;//i控制一次读入一个字符 
    }
    
    return 0;
}


 

0.0分

11 人评分

  评论区