1048. 数字加密(20)
来源:互联网 发布:二维数组下标越界 编辑:程序博客网 时间:2024/06/16 00:40
1048. 数字加密(20)
题目
本题要求实现一种数字加密方法。首先固定一个加密用正整数A,对任一正整数B,将其每1位数字与A的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对13取余——这里用J代表10、Q代表11、K代表12;对偶数位,用B的数字减去A的数字,若结果为负数,则再加10。这里令个位为第1位。
输入格式:
输入在一行中依次给出A和B,均为不超过100位的正整数,其间以空格分隔。
输出格式:
在一行中输出加密后的结果。
输入样例:
1234567 368782971
输出样例:
3695Q8118
思路
注意位数不够时要在前面补零,处理的时候注意,补零的位数对于计数的加法是原字符串输出,但是偶数位就不是了,补零的可能会有负数生成。
代码
#include <stdio.h>#include <stdlib.h>#include <string.h>int main(void){ char re[13]={'0','1','2','3','4','5','6','7','8','9','J','Q','K'}; char a[101],b[101]; scanf("%s %s",a,b); int i,alen,blen,len; alen=strlen(a); blen=strlen(b); len =alen>blen?alen:blen; for(i=0;i<len;i++) { int A,B; A=alen+i-len<0?0:a[alen+i-len]-'0'; B=blen+i-len<0?0:b[blen+i-len]-'0'; if((len-i)%2)printf("%c",re[(A+B)%13]); else printf("%c",re[B-A>=0?B-A:B-A+10]); } return 0;}
阅读全文
0 0
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 1048. 数字加密(20)
- 在Windows中玩转Docker Toolbox
- 1.5.1 Number Triangles 数字金字塔
- java中的参数传递
- Shiro (二) JDBC Realm
- Mybatis问题:There is no getter for property named 'Id' in 'class java.lang.String'
- 1048. 数字加密(20)
- 11.14学习心得
- Python + selenium 实践问题(一)
- 牛客网初级算法(1)
- SQL Server2008 学习之(五) :规则与约束的用法与联系
- 我的校招总结
- 警告: [SetContextPropertiesRule]{Context} Setting property 'source' to 'org.eclipse.jst.jee.server:sss
- xshell远程连接工具不能连接本地刚安装的linux系统(网络模式选择“NAT模式”)
- 用户注册数据库登记