如何根据银行卡号判断卡的真伪

  这个算法是IBM公司的彼得·卢恩(Peter Luhn)于1954年设计的一个校验和(checksum)算法,来检测在实际操作中最常见的两种错误:单个数字错误、由于两个数字写错位置而引起的大多数换位错误。后来这个算法有了很多应用场景,比如可以检测16位长的信用卡和储蓄卡的卡号是否是有效的卡号(这是美国的情况,中国的储蓄卡一般是19位,不过算法同样适用);10 位或13 位的ISBN 书号也采用了类似算法的校验和,用来对付同类错误。
  具体做法:从最右一位数开始向左,把每个数字交替乘1或2,如果结果大于 9就减9。如果把各位数的计算结果加起来,最后得到的总和能被10 整除,那这个卡号就是有效卡号。
  你可以用这个方法测试一下信用卡,以“4417 1234 5678 9112”为例,这个卡号计算的结果是69,所以不是真卡号;如果把它的最后一个数字换成3,那就是有效卡号了。我用该算法测试了自己的银行卡和信用卡,的确可以用来检测卡的真伪,这也算是个小知识吧。

    string card;
    int sum,temp;
    bool even;
    while(cin>>card)
    {
        sum=0;even=0;
       /*
       从最右一位数开始向左,把每个数字交替乘1或2,
       如果结果大于 9就减9。如果把各位数的计算结果加起来,
       最后得到的总和能被10 整除,那这个卡号就是有效卡号。
       */
       //银行账号 4417123456789112
       for(int i=card.length()-1;i>=0;i--)
       {
           if(even)temp=(card[i]-'0')*2;
           else    temp=(card[i]-'0');
           even=!even;
           if(temp>9) temp-=9;
           sum+=temp;
       }
       printf("%d %s\n",sum,(sum%10==0?" 正确的卡号":" 错误"));
    } 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值