zoukankan      html  css  js  c++  java
  • 算法提高 9-3摩尔斯电码

    算法提高 9-3摩尔斯电码  

    时间限制:1.0s   内存限制:256.0MB
     
       
    问题描述
      摩尔斯电码破译。类似于乔林教材第213页的例6.5,要求输入摩尔斯码,返回英文。请不要使用"zylib.h",只能使用标准库函数。用' * '表示' . ',中间空格用' | '表示,只转化字符表。

      摩尔斯码定义见:http://baike.baidu.com/view/84585.htm?fromId=253988。

    提示
      清橙进行评测时,输入是以EOF结尾的,而不是换行符。(EOF不是一个字符,“以EOF结尾”是一种通俗但不严谨的说法。)因此可以通过以下方式之一获取输入:

      1. 一次读入整行字符串,再进行后续解析。

      2. 使用getchar或scanf一次读入一个字符,通过它们的返回值判断输入结束。
    样例输出
    我感觉自己独立思考能力还是太差,这个题本来是应该能做出来的,结果看了一会儿就感觉做不出来,想过用树的结构来存储,但是浅尝辙止了。
    到网上搜的思路,看到的第一眼就知道怎样能做出来了!
    #include <iostream>
    #include <cstdio>
    #include <cmath>
    #include <vector>
    #include <queue>
    #include <cstring>
    #include <algorithm>
    #include <cstdlib>
    #define for(i,x,n) for(int i=x;i<n;i++)
    #define ll long long int
    #define INF 0x3f3f3f3f
    #define MOD 1000000007
    #define MAX_N 50005
    
    using namespace std;
    
    
    int main()
    {
        //freopen("input.txt", "r", stdin);
        //freopen("data.out", "w", stdout);
        char m[33]="1etianmsurwdkgohvf1l1pjbxc1zq11";
        char a[999];
        scanf("%s",a);
        int len=strlen(a);
        int w=0;
        for(i,0,len){
            if(a[i]=='*'){
                w=w*2+1;
            }
            if(a[i]=='-'){
                w=w*2+2;
            }
            if(a[i]=='|'){
                printf("%c",m[w]);
                printf("");
                w=0;
            }
        }
        printf("%c",m[w]);
        //fclose(stdin);
        //fclose(stdout);
        return 0;
    }
    // ****|*|*-**|*-**|---
  • 相关阅读:
    C语言版本:单链表的实现(优化版本)
    C语言版本:单链表的实现
    C语言版本:顺序表的实现
    C++:多态浅析
    C++:同名隐藏和赋值兼容规则
    C++:钻石继承与虚继承
    C++:派生类的构造函数和析构函数的调用顺序
    Docker安装和使用
    Node10.15.0的安装
    碎碎叨叨
  • 原文地址:https://www.cnblogs.com/TWS-YIFEI/p/6368154.html
Copyright © 2011-2022 走看看