【PTA刷题整理】PAT 乙级 1031 查验身份证

编程入门 行业动态 更新时间:2024-10-25 20:21:48

【PTA刷题整理】PAT <a href=https://www.elefans.com/category/jswz/34/1765193.html style=乙级 1031 查验身份证"/>

【PTA刷题整理】PAT 乙级 1031 查验身份证

2020.04.13 本周末刚刚参加完学校的IT节ACM的线上资格赛,感觉自己还是挺喜欢算法,而且自己的能力还是很弱,三天才做出来五题,需要多多练习,多忙都得挤出点时间来做题


1031 查验身份证 (15分)

一个合法的身份证号码由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系统(在线判定),则忽略文件读入,否则使用文件作为标准输入
#elsefreopen("1.txt", "r", stdin);   //从1.txt输入数据
#endifint 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;                       
}

更多推荐

【PTA刷题整理】PAT 乙级 1031 查验身份证

本文发布于:2024-02-25 21:04:42,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1700291.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:乙级   身份证   PTA   PAT

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!