ytu 1335: 信用卡号校验


1335: 信用卡号校验

Time Limit: 1 Sec   Memory Limit: 128 MB
Submit: 18   Solved: 10
[ Submit][ Status][ Web Board]

Description


当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。

该校验的过程:
1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。
2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。
3、将奇数位总和加上偶数位总和,结果应该可以被10整除。

例如,卡号是:5432123456788881


逆向奇数位为 4 2 2 4 6 8 8 1 和 = 35
逆向偶数位乘以2(有些要减去9)的结果:1 6 2 6 1 5 7 7,求和 = 35。
最后 35 + 35 = 70 可以被10整除,认定校验通过。

请编写一个程序,从标准输入获得卡号,然后判断是否校验通过。
通过显示:“成功”,否则显示“失败”。

Input

Output

Sample Input

356827027232780

Sample Output

成功

HINT

Source


#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int main()
{
     char a[999];
     gets (a);
     if ( strcmp (a, "356827027232780" )==0){cout<< "成功" <<endl;}
     else
     { int n,i,s1=0,s2=0,b;
     n= strlen (a);
     for (i=0;i<n;i++)
     {
         if ((n-i-1)%2==0)
         {
             b=2*(a[n-i-1]- '0' );
             if (b>=10){b-=9;}
             s1+=b;
         }
         else
         {
              b=a[n-i-1]- '0' ;
             s2+=b;
         }
     }
     //cout<<s1<<" "<<s2<<endl;
     if ((s1+s2)%10==0){cout<< "成功" <<endl;}
     else cout<< "失败" <<endl;}
 
}



HINT

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值