赞
踩
2020.04.13 本周末刚刚参加完学校的IT节ACM的线上资格赛,感觉自己还是挺喜欢算法,而且自己的能力还是很弱,三天才做出来五题,需要多多练习,多忙都得挤出点时间来做题
一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:
首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};然后将计算的和对11取模得到值Z;最后按照以下关系对应Z值与校验码M的值:
Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2
现在给定一些身份证号码,请你验证校验码的有效性,并输出有问题的号码。
输入格式:
输入第一行给出正整数N(≤100)是输入的身份证号码的个数。随后N行,每行给出1个18位身份证号码。
输出格式:
按照输入的顺序每行输出1个有问题的身份证号码。这里并不检验前17位是否合理,只检查前17位是否全为数字且最后1位校验码计算准确。如果所有号码都正常,则输出All passed。
输入样例1:
4
320124198808240056
12010X198901011234
110108196711301866
37070419881216001X
输出样例1:
12010X198901011234
110108196711301866
37070419881216001X
输入样例2:
2
320124198808240056
110108196711301862
输出样例2:
All passed
今天这个十五分的题很简单,可以用很多种方式将模后的值Z和校验码M的值,对应存储起来,可以用map,字符数组,太久没用过switch() ,这里就直接用个switch()来取就好了,用isdigit()来判断是否为数字
#include<iostream> //输入输出流头文件 #include<stdio.h> //标准输入输出 #include<stdlib.h> #include<math.h> //数学函数 #include<string.h> //C语言字符数组的字符串 #include<algorithm> //C++标准模板库的函数 #include<map> //map映射容器 #include<unordered_map> //无序的map映射容器 #include<vector> //变长数组容器 #include<queue> //队列 #include<stack> //栈 #include<string> //C++string类 #include<set> //set集合 using namespace std; //标准命名空间 //可以加入全局变量或者其他函数 int main(){ //主函数 #ifdef ONLINE_JUDGE //如果有oj系统(在线判定),则忽略文件读入,否则使用文件作为标准输入 #else freopen("1.txt", "r", stdin); //从1.txt输入数据 #endif int N; cin >> N; string str[N]; int sum[N]; memset(sum , 0 , sizeof(sum)); bool judge[N]; memset(judge , true , sizeof(judge)); int w[17] = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2}; for(int i = 0 ; i < N ; i++){ cin >> str[i]; for(int j = 0 ; j < 17 ; j++){ int total = 0; if(isdigit(str[i][j]) == 0){ judge[i] = false; //cout << "Error" << endl; break; }else{ int temp = str[i][j] - '0'; //cout << str[i][j] << "--" << temp << endl; //cout << "temp * w[j] : " << temp * w[j] << endl; total += temp * w[j]; //cout << "---" << sum[i] << endl; } sum[i] += total; } //cout << endl; //cout << sum[i] << endl; } for(int i = 0 ; i < N ; i++){ if(judge[i]){ //cout << i << " -- "<<sum[i] << endl; sum[i] %= 11; //cout << i << " -- "<<sum[i] << endl; int a = sum[i]; char cmp = 0; switch (a){ case 0: cmp = '1'; break; case 1: cmp = '0'; break; case 2: cmp = 'X'; break; case 3: cmp = '9'; break; case 4: cmp = '8'; break; case 5: cmp = '7'; break; case 6: cmp = '6'; break; case 7: cmp = '5'; break; case 8: cmp = '4'; break; case 9: cmp = '3'; break; case 10: cmp = '2'; break; } //cout << "str[i][18]:" <<str[i][17] << endl; if(str[i][17] != cmp){ judge[i] = false; } //cout << "cmp:" << cmp << endl; } } int index = 1; for(int k = 0 ; k < N ; k++){ if(!judge[k]){ cout << str[k] << endl; index = -1; } } if(index == 1){ cout << "All passed" << endl; } return 0; }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。