标签:20 测试点 num2 int 1048 num size num1
https://pintia.cn/problem-sets/994805260223102976/problems/994805276438282240
百度之后,发现测试点2、5就是在A的位数大于B的位数的情况,B前面要添加‘0’再进行加密。
#include<iostream>
using namespace std;
int main() {
string a, b;
cin >> a >> b;
int i=a.size()-1, j=b.size()-1, k=1;
int num1, num2, num;
if(i>j){
for(int m=0; m<i-j; m++){
b = '0' + b;
}
j = i;
}
for(; i>=0 && j>=0; i--, j--, k++){
num1 = a[i]-'0';
num2 = b[j]-'0';
// 奇数位
if(k%2!=0){
num = (num1+num2)%13;
// 偶数位
}else{
num = num2-num1;
if(num<0){
num += 10;
}
}
if(num == 10){
b[j] = 'J';
}else if(num == 11){
b[j] = 'Q';
}else if(num == 12){
b[j] = 'K';
}else{
b[j] = num+'0';
}
}
cout << b << endl;
return 0;
}
标签:20,测试点,num2,int,1048,num,size,num1 来源: https://blog.csdn.net/qq_33514421/article/details/114190123
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。