关于c++:AY-破译邮件基础上机试题

小明收到了一封很奇怪的邮件,外面全是一些符号和数字,然而信下面给出了破译办法,具体方法如下:
(1)将1变为‘A’,2变为‘B’,…,26变为‘Z’;
(2)将‘#’变为一个空格;
(3)疏忽‘-’,原始函件中‘-’仅仅用来宰割数字。
现请你编程帮忙小明破译这封邮件。
输出
输出的第一行为一个整数C,示意测试数据的组数。
接下来C行,每行输出一个待破译的字符串,字符串中只蕴含数字、‘-’和‘#’,长度不超过100。
输入
对于每组输出,输入破译后的文本。
样例输出 Copy
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
样例输入 Copy
I WILL STEAL AT LEAST ONE JEWEL
AND LEAVE THE MUSEUM IN T MINUTES
AFTER THE OPENING OF THE EXHIBITION
GOOD LUCK

代码示例(本人写的,只能过平台,不完满)

//#include<iostream>
//#include<string.h>
//#include<cstdio>
//#include<cstring>
//#include<algorithm>
//using namespace std;
//int main()
//{
//    int n = 0;
//    char s[101],a[101];
//    scanf("%d",&n);
//    while(n--){
//        int i = 0;
//        int j = 0;
//        scanf("%s",s);
//        for(; i < strlen(s); i++){
//            if(s[i] == '#'){
//                a[j] = ' ';
//                j++;
//            }else if((s[i] <= '9' && s[i] >= '1') && (s[i + 1] < '0'||s[i + 1] > '9')){
//                a[j] = s[i] - '0' + 64;
//                j++;
//            }else if((s[i] <= '9' && s[i] >= '1') && (s[i + 1] >= '0'&& s[i + 1] <= '9')){
//                a[j] = (s[i] - '0') * 10 + s[i + 1] - '0' + 64;
//                j++;
//                i++;//此时已胜利转化第i位和第i+1位为字符(同时转化了2位)故须要让下标i再后退一位 
//            }
//        }
//        a[j] = '\0';//不要遗记在新生成的字符串后补充开端字符'\0' 
//        printf("%s\n",a);
//    } 
//    return 0;
//}

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理