解
简单模拟
//
// Created by 29273 on 2021-04-05.
//
#include "bits/stdc++.h"
using namespace std;
char a[13];
int change(char ch) {
return ch - '0';
}
int judge() {
int res = change(a[0]) * 1 + change(a[2]) * 2 + change(a[3]) * 3 + change(a[4]) * 4 + change(a[6]) * 5 +
change(a[7]) * 6 + change(a[8]) * 7 + change(a[9]) * 8 +
change(a[10]) * 9;
if ((res % 11 == a[12] - '0') || ((res % 11 == 10) && (a[12] == 'X'))) {
return 1;
}
if (res % 11 != 10) {
a[12] = (res % 11) + '0';
} else {
a[12] = 'X';
}
return 0;
}
int main() {
cin >> a;
if (judge()) {
printf("Right");
} else {
for (int i = 0; i < 13; ++i) {
printf("%c", a[i]);
}
}
return 0;
}
别人家的精妙代码
#include<bits/stdc++.h>
using namespace std;
int main(){
string input;
getline(cin,input);
int sum=0;
for(int i=0,j=1;i<input.size()-1;++i){//进行权重乘法加和
if(isdigit(input[i]))
sum+=(input[i]-'0')*(j++);
}
sum%=11;//求余
if((sum<=9&&sum==input.back()-'0')||(sum==10&&input.back()=='X'))
printf("Right");
else{
input.back()=(sum==10)?'X':(sum+'0');
printf("%s",input.c_str());
}
return 0;
}