zoukankan      html  css  js  c++  java
  • 验证合法身份证

    验证合法身份证

    /*
     * 计算方法
     *      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;
     *      5、通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的X,如果余数是10,身份证的最后一位号码就是2;
     *
     *  例如:某男性的身份证号码是34052419800101001X。我们要看看这个身份证是不是合法的身份证。
     *  首先:我们计算3*7+4*9+0*10+5*5+...+1*2,前17位的乘积和是189
     *  然后:用189除以11得出的结果是商17余2
     *  最后:通过对应规则就可以知道余数2对应的数字是x。所以,这是一个合格的身份证号码。
     */
    
    - (BOOL)isValidIdentityCard:(NSString *)idCard {
    
      if (idCard.length < 18 || idCard.length > 18) {
        return NO;
      }
    
        // 系数数组
        int factor[] = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };
        // 校验码数组
        char code[] = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' };
        
        // 各位与系数相乘求和
        int result = 0;
        for (int i=0; i<17; i++) {
            int temp = [[idCard substringWithRange:NSMakeRange(i, 1)] intValue];
            result += temp * factor[i];
        }
        
        // 求余取对应验证码
        result = code[result % 11];
        
        // 比较验证码
        if (result == [idCard characterAtIndex:17]) {
            return YES;
        } else {
            return NO;
        }
    }
    
    时常一个人发呆,看到宁静的天空。
  • 相关阅读:
    yzoj P2344 斯卡布罗集市 题解
    yzoj P2350 逃离洞穴 题解
    yzoj P2349 取数 题解
    JXOI 2017 颜色 题解
    NOIP 2009 最优贸易 题解
    CH 4302 Interval GCD 题解
    CH4301 Can you answer on these queries III 题解
    Luogu2533[AHOI2012]信号塔
    Luogu3320[SDOI2015]寻宝游戏
    Luogu3187[HNOI2007]最小矩形覆盖
  • 原文地址:https://www.cnblogs.com/pinweyshg/p/5282342.html
Copyright © 2011-2022 走看看