1038 - 破译邮件
小明收到了一封很奇怪的邮件,里面全是一些符号和数字,但是信上面给出了破译方法,具体方法如下:
(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
C语言解答
#include<stdio.h> #include<string.h> int main() { int c,i,k; char a[101],b[101]; scanf("%d",&c); while(c--) { scanf("%s",a); for(k=i=0;i<strlen(a);i++) { if(a[i]=='#') b[k++]=' '; else if((a[i]>='1'&&a[i]<='9')&&(a[i+1]<'0'||a[i+1]>'9')) b[k++]=a[i]-'0'+64; else if((a[i]>='1'&&a[i]<='9')&&(a[i+1]>='0'&&a[i+1]<='9')) { b[k++]=(a[i]-'0')*10+a[i+1]-'0'+64; i++; } } b[k]='\0'; printf("%s\n",b); } return 0; }
C++解答
#include<stdio.h> #include<string.h> int main() { int c,i,k; char a[101],b[101]; scanf("%d",&c); while(c--) { scanf("%s",a); for(k=i=0;i<strlen(a);i++) { if(a[i]=='#') b[k++]=' '; else if((a[i]>='1'&&a[i]<='9')&&(a[i+1]<'0'||a[i+1]>'9')) b[k++]=a[i]-'0'+64; else if((a[i]>='1'&&a[i]<='9')&&(a[i+1]>='0'&&a[i+1]<='9')) { b[k++]=(a[i]-'0')*10+a[i+1]-'0'+64; i++; } } b[k]='\0'; printf("%s\n",b); } return 0; }