当前位置:   article > 正文

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

pat试题 身份证

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系统(在线判定),则忽略文件读入,否则使用文件作为标准输入
#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;                       
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/713061
推荐阅读
相关标签
  

闽ICP备14008679号