身份证号码升级
来源:互联网 发布:大数据的数据来源 编辑:程序博客网 时间:2024/05/20 21:58
问题描述
从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××年
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位字符串是否合理
#include<stdio.h>
int main()
{
int c[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
char d[11]={'1','0','x','9','8','7','6','5','4','3','2'};
int i,j,a[15],b[18],sum=0,l;
char x[15];
gets(x);
for(i=0;i<15;i++)
{
a[i]=x[i]-'0';//注意:这里的作用是把字符数组转换为数字数组,以便接下来的运算。
}
for(j=0,i=0;j<17,i<17;j++,i++)
{
if(i<6)
{
b[j]=a[i];
}
if(i==6)
{
b[j]=1;
}
if(i==7)
{
b[j]=9;
}
if(i>7)
{
b[j]=a[i-2];
}
}
for(j=0;j<17;j++)
{
sum=sum+b[j]*c[j];
}
l=sum%11;
for(j=0;j<17;j++)
printf("%d",b[j]);
printf("%c\n",d[l]);
return 0;
}
0 0
- 身份证号码升级
- 身份证号码升级
- 身份证号码升级
- 身份证号码升级
- 蓝桥杯 身份证号码升级(模拟)
- 蓝桥杯 - 身份证号码升级
- 蓝桥杯-身份证号码升级
- 蓝桥杯java -身份证号码升级
- 算法提高 身份证号码升级
- 算法提高 身份证号码升级
- 算法提高 身份证号码升级
- 算法提高 身份证号码升级
- 算法提高 身份证号码升级
- 算法提高 身份证号码升级
- 蓝桥杯 算法提高 身份证号码升级
- 算法提高 身份证号码升级 JAVA
- 蓝桥杯算法提高 身份证号码升级
- 蓝桥杯 算法提高 身份证号码升级
- css布局模型
- java调用outlook
- QStorageInfo获取磁盘信息
- 杭电吃糖果问题
- 关于职业的选择
- 身份证号码升级
- HQL实现多表连接+多条件查询
- 最大最小公倍数
- 设计模式之建造者(builder)模式
- Mac升级到macOS Sierra 10.12后SVN管理软件Conerstone破解版安装后提示“已损坏”
- 算法训练 区间k大数查询
- [基础]Map在JSP中的两种显示方式
- 一个高效的a *寻路算法(八方向)
- 机器学习算法实现03-神经网络