博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法笔记_228:信用卡号校验(Java)
阅读量:6234 次
发布时间:2019-06-22

本文共 1190 字,大约阅读时间需要 3 分钟。

目录

 


1 问题描述

当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过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整除,认定校验通过。

请编写一个程序,从标准输入获得卡号,然后判断是否校验通过。

通过显示:“成功”,否则显示“失败”。

比如,

输入:356827027232780
程序输出:成功

 

 


2 解决方案

1 import java.util.Scanner; 2  3 public class Main { 4      5     public static void main(String[] args) { 6         Scanner in = new Scanner(System.in); 7         String S = in.next(); 8         int sum1 = 0, sum2 = 0; 9         for(int i = S.length() - 1, j = 1;i >= 0;i--, j++) {10             if(j % 2 == 1)11                 sum1 = sum1 + (S.charAt(i) - '0');12             else {13                 int temp = (S.charAt(i) - '0') * 2;14                 if(temp >= 10)15                     temp = temp - 9;16                 sum2 = sum2 + temp;17             }18         }19         if((sum1 + sum2) % 10 == 0)20             System.out.println("成功");21         else22             System.out.println("失败");23     }24 }

 

 

运行结果:

358973017867754失败358973017867744成功

 

转载地址:http://jmqna.baihongyu.com/

你可能感兴趣的文章
出去吃顿饭容易嘛(r11笔记第5天)
查看>>
IMP-00009: 导出文件异常结束
查看>>
Java AIO 入门实例(转)
查看>>
SSAS中CUBE行权限数据级权限控制
查看>>
HDOJ(HDU) 2186 悼念512汶川大地震遇难同胞——一定要记住我爱你
查看>>
git 专题
查看>>
c#中const与readonly区别
查看>>
JavaScript---网络编程(11)--DHTML技术演示(4)-单选框/下拉菜单/添加文件
查看>>
解决WebView调用loadData()方法显示乱码的问题
查看>>
ThinkPHP Where 条件中使用表达式
查看>>
WPF 引用DLL纯图像资源包类库中的图片
查看>>
Redis集群_3.redis主从自动切换Sentinel(转)
查看>>
Android零基础入门第45节:GridView简单使用
查看>>
读书笔记---操作系统概论
查看>>
从ASCII聊起
查看>>
大数据和Hadoop时代的维度建模和Kimball数据集市
查看>>
Android官方入门文档[3]构建一个简单的用户界面
查看>>
编写出色CSS代码的13个建议
查看>>
Alluxio之IO选项:读写类型
查看>>
ECS centos7安装elasticsearch2.4.1填坑日记
查看>>