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;
}

posted @ 2020-11-05 01:01  罪梦者  阅读(107)  评论(0)    收藏  举报