字符串水题——破译邮件

问题 F: 破译邮件

时间限制: 1 Sec   内存限制: 32 MB
提交: 6   解决: 6
[ 提交][ 状态][ 讨论版]

题目描述

小明收到了一封很奇怪的邮件,里面全是一些符号和数字,但是信上面给出了破译方法,具体方法如下:
(1)将1变为‘A’,2变为‘B’,...,26变为‘Z’;
(2)将‘#’变为一个空格;
(3)忽略‘-’,原始信件中‘-’仅仅用来分割数字。
现请你编程帮助小明破译这封邮件。

输入

输入的第一行为一个整数C,表示测试数据的组数。
接下来C行,每行输入一个待破译的字符串,字符串中只包含数字、‘-’和‘#’,长度不超过100。

输出

对于每组输入,输出破译后的文本。

样例输入

4
9#23-9-12-12#19-20-5-1-12#1-20#12-5-1-19-20#15-14-5#10-5-23-5-12
1-14-4#12-5-1-22-5#20-8-5#13-21-19-5-21-13#9-14#20#13-9-14-21-20-5-19
1-6-20-5-18#20-8-5#15-16-5-14-9-14-7#15-6#20-8-5#5-24-8-9-2-9-20-9-15-14
7-15-15-4#12-21-3-11

样例输出

I WILL STEAL AT LEAST ONE JEWEL
AND LEAVE THE MUSEUM IN T MINUTES
AFTER THE OPENING OF THE EXHIBITION
GOOD LUCK

提示


分析:这个题用流做不了,因为流里面是一堆字符不是字符串很不好处理,所以就朴素的做,瞎搞就好了。


#include <bits/stdc++.h>
 
using namespace std;
 
 
 
int main()
{
    string a;
 
    int t;
    cin>>t;
 
    getchar();
 
    while(t--)
    {
        getline(cin,a);
 
 
        for(int i=0;i<a.length();i++)
        {
 
            if(a[i]=='#')
            {
                cout<<' ';
            }
 
            if(isdigit(a[i]))
            {
                if(isdigit(a[i+1]))
                {
                    printf("%c",(a[i]-48)*10+a[i+1]-48 +64);
                    i++;
                }
 
                else
                {
                    printf("%c",a[i]+16);
                }
            }
 
 
        }
 
         cout<<endl;
    }
 
 
    return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值