1048 数字加密 (20分)
1048 数字加密 (20分)
本题要求实现一种数字加密方法。首先固定一个加密用正整数 A,对任一正整数 B,将其每 1 位数字与 A 的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对 13 取余——这里用 J 代表 10、Q 代表 11、K 代表 12;对偶数位,用 B 的数字减去 A 的数字,若结果为负数,则再加 10。这里令个位为第 1 位。
输入格式:
输入在一行中依次给出 A 和 B,均为不超过 100 位的正整数,其间以空格分隔。
输出格式:
在一行中输出加密后的结果。
输入样例:
1234567 368782971
输出样例:
3695Q8118
代码讲解:这题很坑爹啊,一看看上去感觉很容易,写了代码之后,总有俩个过不去,我就试验了
几种情况,终于让我试验通过了,原来当它b字符串较小的时候,还是要继续算的。。。这种只能
通过试验去发现,算埋伏的一个坑吧
#include<stdio.h>
#include<string.h>
int main()
{
char a[201]={0};
char b[201]={0};
scanf("%s %s",a,b);
int count=0;
int i,j,k;
int temp;
int str_lena=strlen(a);
int str_lenb=strlen(b);
int str_len=str_lena>str_lenb?str_lena:str_lenb;
char c[str_len+1];
for(k=str_len-1,i=str_lena-1,j=str_lenb-1;k>=0;k--,i--,j--)
{
count++;
if(count%2==1)
{
temp=(i>=0?a[i]-'0':0)+(j>=0?b[j]-'0':0);
temp=temp%13;
}
else
{
temp=((j>=0?b[j]-'0':0)-(i>=0?a[i]-'0':0)+10)%10;
}
c[k]=temp;
}
for(i=str_len-1;i>=0;i--)
{
switch(c[i])
{
case 10:c[i]='J';break;
case 11:c[i]='Q';break;
case 12:c[i]='K';break;
default: c[i]+='0';
}
}
c[str_len]=0;
printf("%s",c);
printf("\n");
return 0;
}