L1-016 查验身份证

L1-016 查验身份证
L1-016 查验身份证
查验身份,emmmm…,应该注意,需要判断的是其实是三个:
(1)前十七位数字均为数字。
(2)最后一位对应准确。
(3)输入的身份证号是18位。
前两个判断点,分别用flag1和flag2用来记录真假,第三个判断点从逻辑上来说也是很必要的!,但是多次提交发现PTA系统对于这道题的测试点里面并没有第三个测试点,仅用前两个判断点就能AC,充分说明了这道题的测试样例的不严谨性,但还是建议写完整。下面的代码里面对这三个判断点都进行了完整的判断。

#include<iostream>
#include<string>

using namespace std;

int main()
{
	int Q[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
	char M[17]={'1','0','X','9','8','7','6','5','4','3','2'};
	string ID;
	int N;
	cin>>N;
	bool flag1=true;//flag1用来记录前17位是否位数字 
	bool flag2=true;//flag2用来记录最后一位是否准确 
	while(N--)
	{
		cin>>ID;
		int sum=0;
		flag1=true;
		for(int i=0;i<ID.size()-1;i++)
		{//遍历-前17位 
			if(ID[i]>='0'&&ID[i]<='9')
			{//如果前17位均为数字 
				sum+=Q[i]*(ID[i]-48);			
			}
			else
			{
				flag1=false;
			 } 
		}
		if(flag1==false || ID.size()!=18)
		{// 如果前17位不正常 
			cout<<ID<<endl;
		 } 
		else
		{
			if(M[sum%11]!=ID[17])
			{
				flag2=false;
				cout<<ID<<endl;
			}
		}
	}
	if(flag1==true && flag2==true &&ID.size()==18)
	{//如果flag1和flag2均正常,并且输入为18位数字 
		cout<<"All passed"<<endl;
	}
	return 0;
}
上一篇:python – 循环列表中两个元素之间的最小距离?


下一篇:JS 基础DOM 点击获取时间