信用卡号校验
/*
当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过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; } |
信用卡号校验
最新推荐文章于 2023-05-30 11:00:39 发布