本题要求实现一种数字加密方法。首先固定一个加密用正整数A,对任一正整数B,将其每1位数字与A的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对13取余——这里用J代表10、Q代表11、K代表12;对偶数位,用B的数字减去A的数字,若结果为负数,则再加10。这里令个位为第1位。
输入格式:
输入在一行中依次给出A和B,均为不超过100位的正整数,其间以空格分隔。
输出格式:
在一行中输出加密后的结果。
输入样例:
1234567 368782971
输出样例:
3695Q8118
提交代码
//00:14-00:21-00:38
#include <stdio.h>
#include <string.h>
int main(){
char A1[105],A[105];int A_len,B_len,max;
char B1[105],B[105];
char C[105];
int i,j;int tag=0;
scanf("%s%s",A,B);
A_len = strlen(A);
B_len = strlen(B);
max=A_len>B_len?A_len:B_len;
for(i=A_len-1,j=1;i>=0;j++,i--)
A1[j]=A[i];
for(;j<=max;j++)
A1[j]='0';
for(i=B_len-1,j=1;i>=0;j++,i--)
B1[j]=B[i];
for(;j<=max;j++)
B1[j]='0';
for(i=1;i<=max;i++){
if(i%2==1){
tag=(A1[i]-'0'+B1[i]-'0')%13;
if(tag==10)
C[i-1]='J';
else if(tag==11)
C[i-1]='Q';
else if(tag==12)
C[i-1]='K';
else{
C[i-1]=tag+'0';
}
}else{
tag=B1[i]-A1[i];
if(tag<0){
C[i-1]=tag+10+'0';
}else{
C[i-1]=tag+'0';
}
}
}
// printf("%d %d %d\n",max,A_len,B_len);
i-=2;
for(;i>=0;i--){
printf("%c",C[i]);
}
return 0;
}