身份证号码升级[蓝桥杯][算法提高]

身份证号码升级[蓝桥杯][算法提高]

时间限制: 1Sec 内存限制: 128MB

题目描述

从1999年10月1日开始,公民身份证号码由15位数字增至18位。(18位身份证号码简介)。升级方法为:
1、把15位身份证号码中的年份由2位(7,8位)改为四位。
2、最后添加一位验证码。验证码的计算方案:
将前 17 位分别乘以对应系数 (7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2) 并相加,然后除以 11 取余数,0-10 分别对应 1 0 x 9 8 7 6 5 4 3 2。
请编写一个程序,用户输入15位身份证号码,程序生成18位身份证号码。假设所有要升级的身份证的四位年份都是19××年

输入

一个15位的数字串,作为身份证号码

输出

一个18位的字符串,作为升级后的身份证号码

样例输入

110105491231002

样例输出

11010519491231002x

提示

不用判断输入的15位字符串是否合理

思路:

以字符串的形式输出身份证号码,在第6、7位中插入1和9,计算验证码,最后输出

代码:

#include<stdio.h>
int main()
{
	char a[19];
	int b[]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
	int i=16,j=14;
	int sum=0;
	scanf("%s",a);
	while(i>7)
	{
		a[i]=a[j];
		i--,j--;
	}
	a[6]='1',a[7]='9';
	for(i=0;i<=16;i++)
		sum+=(a[i]-48)*b[i];
	switch(sum%11)
	{
		case 0:a[17]='1';break;
		case 1:a[17]='0';break;
		case 2:a[17]='x';break;
		case 3:a[17]='9';break;
		case 4:a[17]='8';break;
		case 5:a[17]='7';break;
		case 6:a[17]='6';break;
		case 7:a[17]='5';break;
		case 8:a[17]='4';break;
		case 9:a[17]='3';break;
		case 10:a[17]='2';break;
	}
	a[18]='\0';
	printf("%s",a);
return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_44339734/article/details/85463583