新手启示者
每一个人自出生后都会有一个身份证号码。根据我国有关部门规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。 居民身份证是国家法定的证明公民个人身份的有效证件。例如:对于身份证号码330719196804253671,其中330719表示地址码,19680425表示出生日期码,367表示顺序码,最后一个1表示数字校验码。
数字校验码的计算方法:
1、将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2。
2、将这17位数字和系数相乘的结果相加。
3、用加出来的和除以11,看余数是多少?
4、余数只可能有0-1-2-3-4-5-6-7-8-9-10这11个数字。其分别对应的最后一位身份证的号码为1-0-X -9-8-7-6-5-4-3-2。
5、通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。如果对应的数字是2,身份证的最后一位号码就是罗马数字X。
例如:某人的身份证号码为[53010219200508011X], 我们看看这个身份证是不是合法的身份证。首先我们得出前17位的乘积和[ (5 * 7)+(3 * 9)+(0 * 10)+(1 * 5)+(0 * 8)+(2 * 4)+(1 * 2)+(9 * 1)+(2 * 6)+(0 * 3)+(0 * 7)+(5 * 9)+(0 * 10)+(8 * 5)+(0 * 8)+(1 * 4)+(1 * 2) ]是189,然后用189除以11得出的结果是189/11=17----2,也就是说其余数是2。最后通过对应规则就可以知道余数2对应的检验码是X。所以,可以判定这是一个正确的身份证号码。
你的任务是编写程序判断输入的身份证号码中数字校验码是否正确,如果正确,则仅输出“Right”;如果错误,则输出你认为是正确的身份证号码。
输入描述 Input Description
输入有多行,每一行是一个字符序列,表示一个人的身份证号码(保证输入符合身份证号码的格式要求)。
输出描述 Output Description
对于每一行输入,假如输入的身份证号码的数字校验码正确,那么输出“Right”,否则,按照规定的格式,输出正确的身份证号码。
样例输入 Sample Input
330719196804253671 530102192005080112
样例输出 Sample Output
Right 53010219200508011X
数据范围及提示 Data Size & Hint
[数据范围]
保证输入文件不超过300行。
汪宇航在2021-04-30 20:43:16追加了内容
@赵逸凡 @李瑞曦
@汪恺恒 @曹博扬
@谭迪元
资深守护
#include<bits/stdc++.h>
using namespace std;
int main(){
int a[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2},t;
char b[11]={'1','0','X','9','8','7','6','5','4','3','2'};
string s;
while(cin>>s!=NULL){
int z=0;
for(int i=0;i<17;i++){
t=s[i]-48;
z+=t*a[i];
}
z%=11;
char x=b[z];
if(x==s[17])cout<<"Right"; else cout<<s.substr(0,17)<<x;
cout<<endl;
}
}