版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
题目描述
小明收到了一封很奇怪的邮件,里面全是一些符号和数字,但是信上面给出了破译方法,具体方法如下:
(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
代码1
#include<stdio.h>
#include<iostream>
using namespace std;
int main() {
int N;
scanf("%d",&N);
getchar();
char str[101];
char str1[101];
while(N--) {
gets(str);
int sum=0;
int k=0;//这俩不要放在while上面
for(int i=0; str[i]!='\0'; i++) {
if(str[i]>='0'&&str[i]<='9') { //第一种情况
sum=sum*10+str[i]-'0';//char 换成 int
if(str[i+1]>='0'&&str[i+1]<='9') {
sum=sum*10+str[i+1]-'0';
str1[k++]=sum-1+'A';//sum+64也行
i++;//别忘了 两个字符换成一个了
sum=0;
} else {
str1[k++]=sum-1+'A';
sum=0;
}
} else if(str[i]=='#') { //第二种情况
str1[k++]=' ';
} else if(str[i]=='-') { //第三种情况
continue;
}
}
for(int i=0; i<k; i++) {
printf("%c",str1[i]);
}
printf("\n");
}
return 0;
}
代码2
#include<stdio.h>
#include<ctype.h>//
int main(){
int n;
scanf("%d",&n);
getchar();
char str[101];
while(n--){
gets(str);
for(int i=0;str[i]!='\0';i++){
if(isalnum(str[i])&&!isalnum(str[i+1])){//
printf("%c",str[i]-'0'+64);
}
else if(isalnum(str[i])&&isalnum(str[i+1])){
printf("%c",(str[i]-'0')*10+str[i+1]-'0'+64);
i++;//别忘了
}
else if(str[i]=='#'){
printf(" ");
}
}
printf("\n");
}
return 0;
}