信用卡号遵循某种模式。一个信用卡号必须是13到16位的整数。它的开头必须是:
4,指Visa卡
5,指Master卡
37,指American Express 卡
6,指Discover卡
1954年,IBM的Hans Luhn提出一种算法,用于验证信用卡号的有效性。这个算法在确定输入的卡号是否正确,或者这张信用卡是否被扫描仪正确扫描方面是非常有用的。遵循这个合法性检测可以生成所有的信用卡号,通常称之为Luhn检测或者Mod 10检测,可以如下描述(为了方便解释,假设卡号4388576018402626):
(1)从右到左对偶数位数字翻倍。如果对某个数字翻倍之后的结果是一个两位数,那么就将这两位加在一起得到一位数。
(2)现在将第一步得到的所有一位数相加。
(3)将卡号里从右到左奇数位上的所有数字相加。
(4)将第二步和第三步得到的结果相加。
(5)如果第四步得到的结果能被10整除,那么卡号是合法的;否则,卡号是不合法的。例如,号码4388576018402626是不合法的,但是号码4388576018410707是合法的。
编写程序,提示用户输入一个long型整数的信用卡号码,显示这个数字是合法的还是非法的。
使用下面的方法设计程序:
public static boolean isValid(long number)
public static int sumOfDoubleEvenPlace(long number)
public static int getDigit(int number)
public static int sumOfOddPlace(long number)
public static boolean prefixMatched(long number, int d)
public static int getSize(long d)
public static long getPrefix(long number, int k)
下面是程序的运行示例:(你也可以通过将输入作为一个字符串读入,以及对字符串进行处理来验证信用卡卡号。)

package 学习;
import java.util.*;
public class study
{//如果卡号有效,返回truepublic static boolean isValid(long number){if(getSize (number)<13){System.out.println("输入的信用卡号"+number+"共有"+getSize (number)+"位小于13位,有误");return false;}else if(getSize (number)>16){System.out.println("输入的信用卡号"+number+"共有"+getSize (number)+"位超过16位,有误");return false;}else{return true;}}//从Step2中得到结果public static int sumOfDoubleEvenPlace (long number){int sum=0;String number1 =String.valueOf (number);for(int i=getSize (number)-2;i>=0;i-=2){sum=sum+getDigit (2*(number1.charAt(i)-48));//charAt(i)返回的是ASCII码的大小,减去48可以得到i位置上的数字真值}return sum;}//如果是单个数字,则返回该数字,否则返回两位数的和public static int getDigit (int number){if(number<=9){return number;}else{return 1+number%10;}}//返回奇位数之和。public static int sumOfOddPlace (long number){int sum=0;String number1 =String.valueOf (number);for(int i=getSize (number)-1;i>=0;i-=2){sum=sum+getDigit (number1.charAt(i)-48);}return sum;}//返回true,如果d是number的前缀public static boolean prefixMatched(long number,int d){String number1 =String.valueOf (number);if(getSize (d)==1){if (d==4||d==5||d==6){return true;}else{return false;}}else if(getSize (d)==2){int temp=(number1.charAt(0)-48)*10+(number1.charAt(1)-48);if (temp==37){return true;}else{return false;}}else{return false;}//return true;}//返回d的位数。public static int getSize (long d){String d1 =String.valueOf (d);return d1.length();}//返回数字的第一个k位数。如果number中的位数小于k,则返回numberpublic static long getPrefix(long number,int k){String number1 =String.valueOf (number);if(getSize (number)<k){return number;}else{int temp=0;for(int i=0;i<k;i++){temp=10*temp+number1.charAt(i)-48;}return temp;}}public static void main(String[] args) {     System.out.println("请输入一个长整型数字作为信用卡号,长度应在13~16之间");Scanner input =new Scanner (System.in);long num =input.nextLong();if(isValid(num)){if(prefixMatched(num,(int)getPrefix(num,1))||prefixMatched(num,(int)getPrefix(num,2))){if((sumOfDoubleEvenPlace (num)+sumOfOddPlace (num))%10==0){System.out.println("输入的卡号有效");}else{System.out.println("输入的卡号无效");}}else{System.out.println("输入的信用卡号"+num+"前缀有误");}}}
}

金融应用:信用卡号的合法性验证相关推荐

  1. Java黑皮书课后题第6章:**6.31(金融应用:信用卡号的合法性验证)和**6.32 编写程序,提示用户输入一个long型整数的信用卡号码,显示这个数字是合法的还是非法的

    6.31(金融应用:信用卡号的合法性验证)编写程序,提示用户输入一个long型整数的信用卡号码,显示这个数字是合法的还是非法的 6.31题目 题目描述 破题 6.31代码 6.32 代码 运行实例 6 ...

  2. 课内实验记录|信用卡号的合法性检查

    题目要求 (附加题6.31 信用卡号的合法性,可选做) 信用卡号遵循下面的模式.一个信用卡号必须是13-16位的整数.它的开头必须是: 4,指visa卡 5,指master卡 37,指American ...

  3. java 判断是否信用卡_《Java语言程序设计》编程练习6.31(财务应用程序:信用卡号的合法性)...

    6.31(财务应用程序:信用卡号的合法性)信用卡号遵循下面的模式.一个信用卡号必须是13到16位的整数.它的开头必须是: 4,指Visa卡 5,指Master卡 37,指American Expres ...

  4. 转载自---课内实验记录|信用卡号的合法性检查 2019年05月05日 21:37:45 @退堂鼓一级演员

    题目要求 (附加题6.31 信用卡号的合法性,可选做) 信用卡号遵循下面的模式.一个信用卡号必须是13-16位的整数.它的开头必须是: 4,指visa卡 5,指master卡 37,指American ...

  5. Java语言程序设计数据结构基础篇第11版6.31(金融应用:信用卡号的合法性检验)信用卡号遵循某种模式。一个信用卡号必须是13-16位的整数 (java)

    信用卡号遵循某种模式.一个信用卡号必须是13到16位的整数.它的开头必须是: 4,指Visa卡 5,指Master卡 37,指American Express卡 6,指Discover卡 1954年, ...

  6. Java实验3 第十二题:财务应用程序:信用卡号的合法性

    题目描述: 信用卡号遵循下面的模式.一个信用卡号必须是13 到 16 位的整数.它的开头必须是: 4,指 Visa 卡 5,指 Master 卡 37,指 American Express 卡 6,指 ...

  7. Luhn(卢恩)算法,检测信用卡号的合法性

    并不是随便的信用卡号都是合法的,它必须通过Luhn算法来验证. 验证过程: 1. 从卡号最后一位数字开始,逆向将奇数位(1.3.5等等)相加. 2. 从卡号最后一位数字开始,逆向将偶数位数字,先乘以2 ...

  8. 信用卡号的合法性(JAVA)

    题目描述: 思路: 练习一下函数的使用: isValid 判断整个卡号是否有效 sumOfDoubleEvenPlace 基于规则,计算偶数位数的数字和 sumOfDoubleOddPlace 基于规 ...

  9. Python验证信用卡号的有效性(算法)(称为Luhn检测或者mod 10 检测)

    转载自: https://baijiahao.baidu.com/s?id=1662553267127372613&wfr=spider&for=pc 有修改 一个信用卡号必须是13到 ...

最新文章

  1. linux密码加密文件,Linux下加密/解密及用密码保护文件的七把利器
  2. java线程条件变量_多线程同步条件变量(转载)
  3. 【倾情奉献】遥感物候研究:30年长时间序列遥感数据集GIMMS 3g NDVI产品预处理完整步骤
  4. Kafka与RocketMQ的对比分析
  5. 成为高手前必懂的TCP干货
  6. 【MYSQL笔记】使用存储过程
  7. bootstrap 复选框及单选按钮
  8. linux ora03113,ora-03113 问题解决
  9. LayUI的后台管理模板
  10. 微信小程序新版本提示更新
  11. 咳血的独角兽5——挥向投资人的镰刀
  12. GCSE英语语言考试-语言和结构
  13. HBase项目实战:HBase+Flume+Kafka+Hive+SSM实现电信大数据通话信息实时读写定位系统
  14. 数据库SQL语句的增删改查(总结)
  15. 2021.12.28同花顺--智能--选股平台----技术指标--其它指标--逍遥买卖宝--指标B
  16. LeetCode——1217. 玩筹码
  17. ZOJ 3380 Patchouli's Spell Cards [基础概率DP+大数]
  18. Electron打包React构建桌面应用
  19. Debian操作系统定制版---国产凝思linux系统资料
  20. LeetCode 675. 为高尔夫比赛砍树

热门文章

  1. 在Ubuntu上编译gptfdisk的方法
  2. 2021-03-17
  3. [XCode] XCode 6 中修改模拟器版本
  4. Java接入微信支付超级详细教程——从入门到精通
  5. xp系统打印机没有服务器属性设置,xp系统打印机纸张设置的方法
  6. 计算机会计和传统手工会计的区别,会计电算化同传统手工会计的联系与区别
  7. 在CorelDRAW 2019创建对称绘图模式
  8. Qt 数字报阅读器 图文版
  9. 不规律的生活有什么危害
  10. ROM、PROM、EPROM、EEPROM、Flash ROM分别指什么?