B1031
题目描述
一个合法的身份证号码由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
【分析】
0.先写一个isTrue函数来判断是否错误 错误有两方面:1.前17位的输入错误; 2.第18位的检验码错误。
1.设置一flag,一旦有错误,便置flag = 1,以便没有错误时输出allpassed。
2.对于X的处理 由于如果是X 则没法直接与对应检验码比较 判别是否相等,因此若是X则转化为10 (学会下面语句很方便)
int temp = (s[17] == 'X') ? 10 : (s[17] - '0');
3.一次性输出问题 此代码并未解决啊? 难道题目意思并不需要一次性输出?
cout << s << endl;
<< endl 的作用是向缓冲区插入换行符号并刷新,将内容写入输出设备
AC代码
#include<iostream> using namespace std; int a[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; int b[11] = {1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2}; string s; bool isTrue(){ //对s进行判别 int sum = 0; for(int i = 0; i < 17; i++){ if (s[i] < '0' || s[i] > '9') return false; //s[i]此时是直接数字? sum += (s[i] - '0') * a[i]; }//判别是否有输入错误 int temp = (s[17] == 'X') ? 10 : (s[17] - '0');//temp为输入的第18位(若为X(大写)则改为10) return b[sum%11] == temp; //判断第18位是否与检验码相等 利用bool函数返回 } int main(){ int n , flag = 0; cin >> n; for(int i = 0; i < n; i++){ cin >> s; if(!isTrue()){ cout << s << endl;flag = 1; } } if(flag == 0) cout << "All passed"; return 0; }
- 点赞
- 收藏
- 分享
- 文章举报
- PAT 1093 Python
- php经典趣味算法
- 2020-02-23
- 学习笔记1:书单
- 学习笔记3:Ubuntu mac ssh连接
- 学习笔记3(补充):ubuntu root权限、ssh相关命令
- 学习笔记4:ubuntu常用命令
- 学习笔记5:GIT上传项目(个人项目)
- 学习笔记6:前端、后端(B/S)学习路线
- 学习笔记7:C语言:布尔类型、条件运算符 ? :、数组之表驱动法
- 学习笔记8:HTML常用标签(span和div的区别、锚点链接的用法)
- CSS类名命名规则
- 计算机网络发展的7个阶段
- 20-03-11.关于HTML5(学习笔记)
- 关于html5中关于input
- html5中新增的表单元素
- html5中表单新增的事件及进度条
- 关于之前的html5表单总结案例
- html5中的多媒体标签
- CSS样式——选择器