破译邮件

本文介绍了一个编程挑战,即如何解密一封使用特定规则加密的邮件。邮件中的数字和符号需转换为英文字符,以揭示其隐藏的信息。文章提供了详细的解密步骤和一个C++示例代码,展示了如何通过读取和解析输入的加密字符串,将其转换为明文。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

小明收到了一封很奇怪的邮件,里面全是一些符号和数字,但是信上面给出了破译方法,具体方法如下:
(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.三种情况(数字(数字,'-', '#')   '-'     '#')

注意陷阱(1个)

结尾应该如何处理,

/*
 (1)将1变为‘A’,2变为‘B’,...,26变为‘Z’;
 (2)将‘#’变为一个空格;
 (3)忽略‘-’,原始信件中‘-’仅仅用来分割数字。
   9#23-9-12-12#19-20-5-1-12#1-20#12-5-1-19-20#15-14-5#10-5-23-5-1
*/
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
	int m;
	char s[101];
	char a[101];
	cin>>m;
	getchar();
	while(m--)
	{
		scanf("%s",s);
		int k=0;
		int sum=0;
		for(int i=0;i<strlen(s);i++)     //分为3中大情况,
		{
			if(s[i]>='0'&&s[i]<='9')     //数字的话,里面再细分三种情况
			{
				sum=sum*10+s[i]-'0';
			//	printf("%d\n",sum);
				if(s[i+1]>='0'&&s[i+1]<='9')
				{
					sum=sum*10+s[i+1]-'0';
					a[k++]=sum-1+'A';
					//printf("%d***\n",sum-1);
					i++;
					sum=0;
				}
				else if(s[i+1]=='-'||s[i+1]=='\0')  //此陷阱,末尾需要处理
				{
					a[k++]=sum-1+'A';
					//printf("%c***\n",sum-1+'A');
					sum=0;
				}
				else if(s[i+1]=='#')
				{
					a[k++]=sum-1+'A';
					sum=0;
				}
			}
			else if(s[i]=='-')
			{
				continue;
			}
			else if(s[i]=='#')
			{
				a[k++]=' ';
			}
	
		}
		//printf("K:%d %c\n",k,a[0]);
		for(int i=0;i<k;i++)
		printf("%c",a[i]);
		printf("\n");

	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值