游客 Signup | Login
中文 | En

3683 - 身份证

 如果让你设计个程序,用什么变量保存身份证号码呢?长整数可以吗?不可以!
  因为有人的身份证最后一位是"X"
  实际上,除了最后一位的X,不会出现其它字母!
  身份证号码18位 = 17位 + 校验码
  校验码的计算过程:
  例如:身份证前17位 = ABCDEFGHIJKLMNOPQ
  A~Q 每位数字乘以权值求和(每位数字和它对应的“权”相乘后累加)
  17位对应的权值分别是:
  7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
  求出的总和再对11求模
  然后按下表映射:
  余数     0   1   2   3   4   5   6   7   8   9   10
  校验码: 1   0   X   9   8   7   6   5   4   3   2
输入身份证前17位,打印出校验码。

Input

 

Output

Examples

Input

13072719840805463

Output

X

Solution C++

#include<iostream>
using namespace std;
int main()
{
	int weight[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
	string map="10X98765432";
	int i,sum=0;
	string s;
	cin>>s;
	for(i=0;i<17;i++)
	{
		sum+=(s[i]-'0')*weight[i];
	}
	cout<<map[sum%11];
	return 0;
}

Time Limit 1 second
Memory Limit 128 MB
Discuss Stats
上一题 下一题