18位身份证号码最后一位的算法



1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:
  7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 2.将这17位数字和系数相乘的结果相加。 3.用加出来和除以11,得到余数。 4.余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2。
实现:
1.新建对话框程序,加入Edit Control(id为IDC_EDIT1),和一个button(id为IDC_BUTTON1)。设置编辑框属性Number为true,表示只接受数字。

         

2.在OnInitDialog()加入
    // TODO: 在此添加额外的初始化代码    
CFont *m_Font; m_Font = new CFont;
//设置编辑框字体大小 m_Font
->CreateFont(30,10,0,0,100, FALSE,FALSE,0,ANSI_CHARSET,OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,FF_SWISS,L"Arial"); CEdit *m_Edit=(CEdit *)GetDlgItem(IDC_EDIT1); m_Edit->SetFont(m_Font,FALSE); GetDlgItem(IDC_EDIT1)->SetFont(m_Font);

  3.在OnBnClickedButton1()中加入

void CIdCheckDlg::OnBnClickedButton1()
{
    // TODO: 在此添加控件通知处理程序代码
    //系数
    unsigned char multi[17] = {7 ,9 ,10 ,5 ,8 ,4 ,2 ,1 ,6 ,3 ,7 ,9 ,10 ,5 ,8 ,4 ,2}; 
    int sum = 0;
    CString lastNum;

    //获取编辑框的值到编辑框变量
    UpdateData(TRUE);
    CString PersonId;
    PersonId = m_id;
    int ll = PersonId.GetLength();
    //验证长度
    if (ll != 17)
    {
        MessageBox(_T("长度不正确!请输入身份证前17位!"));
        return;
    }
    //计算系数和
    for (int i =0 ; i < ll ; i++)
    {
        sum += _ttoi(CString(PersonId.GetAt(i)))*multi[i];
    }
    //计算余数
    sum %= 11;

    if (sum == 1)
        lastNum = _T("0");
    else if (sum == 0)
        lastNum = _T("1");
    else if (sum == 2)
        lastNum = _T("X");
    else
    {
        lastNum.Format(_T("%d"), 12-sum);
    }
    MessageBox(_T("该身份证最后一位为")+lastNum);
}

 4. 运行结果

        

: 本程序只根据前17位验证最后一位的正确性,而不论该号码的真实性。

 

转载于:https://www.cnblogs.com/fwst/p/3688898.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值