| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1134 人关注过本帖
标题:身份证末位验证码!
取消只看楼主 加入收藏
chen7806
Rank: 1
等 级:新手上路
威 望:2
帖 子:160
专家分:0
注 册:2007-8-5
收藏
 问题点数:0 回复次数:3 
身份证末位验证码!

#include<iostream>
using namespace std;
main()
{
char Ai[17],*p,xn[11]={'1','0','X','9','8','7','6','5','4','3','2'};
int wi[]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
int Aiwi[18],num[18];
int le,i,sum=0;
cout<<"请输入17位身份证号码:";//除个位或15位的从第七位起插入19;
cin>>Ai;
cout<<"新的身份证号码:";
p=Ai;
le=strlen(Ai);
for(i=0;i<le;i++)
{
num[i]=*(p+i)-'0';
Aiwi[i]=num[i]*wi[i];
sum+=Aiwi[i];
cout<<' '<<num[i];
}
cout<<' '<<xn[sum%11];
}

[此贴子已经被作者于2007-9-16 19:37:12编辑过]

搜索更多相关主题的帖子: 身份证 验证 
2007-09-16 19:35
chen7806
Rank: 1
等 级:新手上路
威 望:2
帖 子:160
专家分:0
注 册:2007-8-5
收藏
得分:0 
又更改了一下,请大家完善,菜鸟忙了一个下午。

#include<iostream>
using namespace std;
main()
{
char Ai[17],*p,xn[11]={'1','0','X','9','8','7','6','5','4','3','2'};
int wi[]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
int Aiwi[18],num[18];
int le,i,sum=0;
cout<<"请输入17位身份证号码:";//除个位或15位的第6位起插入19;
cin>>Ai;
p=Ai;
le=strlen(Ai);
if(le!=17)
{
cout<<"请检查输入错误!";
return 0;
}
cout<<"新的身份证号码: ";
for(i=0;i<le;i++)
{
num[i]=*(p+i)-'0';
Aiwi[i]=num[i]*wi[i];
sum+=Aiwi[i];
cout<<num[i];
}
cout<<xn[sum%11];
}

[此贴子已经被作者于2007-10-4 18:17:06编辑过]

2007-09-16 20:02
chen7806
Rank: 1
等 级:新手上路
威 望:2
帖 子:160
专家分:0
注 册:2007-8-5
收藏
得分:0 
以下是引用aipb2007在2007-9-16 21:52:17的发言:
这是干什么用的

因为我的工作接触身份证特别多,有时候15位升18位的,不知道怎么升,在网上查询之后,唯一的身份证末位验证码是计算出来的。所以有这个想法了。

做这个程序,我的体会:

1。字符转数字;
2。数组之间的乘积;
3。数组的乘积之和;
4。指针;
5。求模;
。。。。。。


2007-09-17 08:18
chen7806
Rank: 1
等 级:新手上路
威 望:2
帖 子:160
专家分:0
注 册:2007-8-5
收藏
得分:0 
对了。

如果输入15位的早期身份证号码比如:333333111111444。如何在3与1之间插入19。
2007-09-17 08:22
快速回复:身份证末位验证码!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024510 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved