现在的位置: 首页 > 综合 > 正文

信用卡号校验

2014年06月24日 ⁄ 综合 ⁄ 共 723字 ⁄ 字号 评论关闭
信用卡号校验
/*
当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。
该校验的过程:
1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。
2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。
3、将奇数位总和加上偶数位总和,结果应该可以被10整除。
*/
#include
using namespace std;
void main()
{
 int count =0;//记录卡号长度
 char s[30];//存储卡号
 intsum1=0,sum2=0,sum3=0;//sum1:逆向奇数位和;sum2:逆向偶数位乘以2的结果,sum3:逆向偶数位乘以2(有些要减去9)的结果的和;
 cout<<"请输入卡号:";
 cin>>s;
 //计算卡号长度
 for(int i=0;i<30;i++)
 {
  if(s[i]>='0'&&s[i]<='9')
  count++;
 }
 //逆向奇数位求和
 for(int j=count-1;j>=0;j--)
 {
  sum1+=s[j]-48;
  j--;
 }
 //逆向偶数位乘以2(有些要减去9)的结果的和
 for(int k=count-2;k>=0;k--)
 {
  sum2=(s[k]-48)*2;
  if(sum2>9)
   sum3+=sum2-9;
  else
   sum3+=sum2;
  k--;
 }
 if((sum1+sum3)%10==0)
  cout<<"验证结果:成功!"<<endl;
 else
  cout<<"验证结果:失败!"<<endl;
}

抱歉!评论已关闭.