蓝桥杯2011高职组第9题

当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。 
该校验的过程: 
1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。 
2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。 
3、将奇数位总和加上偶数位总和,结果应该可以被10整除。 例如,卡号是:5432123456788881 
则奇数、偶数位(用红色标出)分布:5432123456788881 奇数位和=35 
偶数位乘以2(有些要减去9)的结果:1 6 2 6 1 5 7 7,求和=35。 最后35+35=70 可以被10整除,认定校验通过。  
请编写一个程序,从键盘输入卡号,然后判断是否校验通过。通过显示:“成功”,否则显示“失败”。 

比如,用户输入:356827027232780 程序输出:成功

#include <stdio.h>
#include <string.h>


int main(){
    char nt[20];
    gets(nt);
    int n[20],i,sum1=0,sum2=0,sum;
    
    for(i=0;nt[i]!='\0';i++){ //转换整形数组 
      n[i] = nt[i] - '0';
      printf("%d\n",n[i]);
      //getchar();
    }
    
    for(i=0;n[i]<strlen(nt);i++){  //分情况 奇就加 偶就判断再加 
      if((i+1)%2){
        sum1 += n[i];
        //printf("sum1=%d,",sum1);
        }
      else{
        n[i] *= 2;
        if(n[i]>9) n[i] -= 9;
        sum2 += n[i];
      }
    }
    sum = sum1+sum2;
    printf("%d,%d,%d",sum1,sum2,sum);
    printf("%s",sum%10==0?"是":"不是");
    getchar();
}

文章由http://www.400815.com原创,转载请注明。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值