题目要求

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

在1954年,IBM的Hans Luhn提出一种算法,该算法可以验证信用卡号的有效性。这个算法在确定输入的卡号是否正确,或者这张信用卡是否能被正确扫描是非常有用的。该方法通常被称为Luhn检测或Mod10 检测,描述如下(假设卡号是4388576018402626)
(1)从右至左对偶数位上的数字翻倍。如果数字翻倍后是一个两位数,那么就将这两位加在一起得到一位数。
2 * 2 =4
2 * 2=4
4 * 2=8
1 * 2=2
6 * 2=12(1+2=3)
5 * 2=10(1+0=1)
8 * 2=16(1+6=7)
4 * 2=8
(2)将第一步得到的所有一位数相加。
4+4+8+2+3+1+7+8=37
(3)将卡号里从右往左奇数位上所有数字相加。
6+6+0+8+0+7+8+3=38
(4)将第二步和第三步得到的结果相加。
37+38=75
(5)如果第四步得到的结果能被10整除,则卡号是合法的,否则是不合法的。
75%10 !=0

编写程序,提示用户输入一个long型整数的信用卡号码,显示这个数字是合法还是非法的。使用下面的方法设计程序:

/Return true if the card number is valid/
public static boolean isValid(long number)

/Get the result from step 2/
public static int sumOfDoubleEvenPlace(long number)

/Return this number if it is a single digit, otherwise return the sum of the two digits/
public static int getDigit(int number)

/Return sum of odd place digits in number/
public static int sumOfOddPlace(long number)

/Return true if the digit d is a prefix for number/
public static boolean prefixMatched(long number, int d)(这个费了死劲也没用上=.=)

/Return the number of digits in d/
public static int getSize(long d)

/Return the first k number of digits from number. If the number of digits in number is less than k, return number/
public static long getPrefix(long number, int k)

实验报告内容

1.实验运行

首先根据提示输入一个长整型的信用卡号

再输入信用卡号

如果信用卡不合法,提示不合法


如果信用卡合法,提示合法

如果输入无效,提示输入无效

2.结果分析

A.实验思路

主函数思路:
根据提示输入长整型信用卡号,先判定是否有效,再对信用卡号的反偶数位和反奇数位求和并判断是否整除10,输出结果;
getSize函数思路:
先取count 为1,在信用卡号除10非0时每存在一次计数器加一,直到除尽,然后返回count;
getPrefix函数思路:
对输入的前缀的位数,减去getSize的长度数并减去前缀数,然后除10操作其次数次,得到的结果即为prefix;
isValid函数思路:
判断长度:13-16位,调用getSize函数
判断前缀:3,4,5,37,调用getPrefix函数
getDigit函数思路:
对输入的数判断,如果大于10,将num % 10 + 1的结果返回(即将两位的数字相加,十位数字一定是1);否则返回原值
sumOfDoubleEvenPlace函数思路:
首先除10到第二位;
然后模10取最后一位,判断是否是两位数(调用getDigit函数),返回值后将其加到sum上,除去100得到下两位的数,重复操作直到除尽,返回sum;
sumOfOddPlace函数思路:
同sumOfDoubleEvenPlace函数思路但不用进行getDigit判断

B.实验改进

使用while(true),break结构实现长时间处理,输入0时结束操作;

3.源代码

**Experiment5**
import java.util.Scanner;public class experiment5 {/*Return the number of digits in d*/public static int getSize(long d){int count = 1;while(d / 10 != 0){d /= 10;count++;}return count;}/*Return the first k number of digits from number. If the number of digits in number is less than k, return number*/public static long getPrefix(long number, int k){int index = getSize(number) - k;for(int i =0; i < index;i++)number /= 10;return number;}/*Return true if the card number is valid*/public static boolean isValid(long number){if(getSize(number)>= 13 && getSize(number)<= 16 && (getPrefix(number, 1) == 4 || getPrefix(number, 1)== 5 || getPrefix(number, 1)== 6 || getPrefix(number, 2)==37))return true;else return false;}/*Return this number if it is a single digit, otherwise return the sum of the two digits*/public static int getDigit(int number){int re = 0;if(number >= 10){re = number % 10 + 1;}else re = number;return re;}/*Get the result from step 2*/public static int sumOfDoubleEvenPlace(long number){number /= 10;int sum = 0;while(number != 0){int temp = (int) (number % 10 * 2);sum += getDigit(temp);number /= 100;}return sum;}/*Return sum of odd place digits in number*/public static int sumOfOddPlace(long number){int sum = 0;while(number != 0){sum += number % 10;number /= 100;}return sum;}public static void main(String[] args){//持续输入while(true){Scanner input = new Scanner(System.in);System.out.println("请输入一个长整型的信用卡号,以0结束");long num = input.nextLong();if(num == 0){ System.out.println("程序结束");break;}int size = getSize(num);//当有效时,将奇偶数结果相加进行判断if(isValid(num)){int sum1 = sumOfDoubleEvenPlace(num);int sum2 = sumOfOddPlace(num);int sum = sum1+sum2;if(sum % 10 == 0)System.out.println("这个卡号是合法的");else System.out.println("这个卡号是不合法的");       }//当无效时,提示else System.out.println("这个卡号是无效的");}}
}

课内实验记录|信用卡号的合法性检查相关推荐

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

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

  2. 【数据库系统原理】数据库课内实验

    说明:这是武汉理工大学计算机学院[数据库系统原理]课程课内实验. >>点击查看武汉理工大学计算机专业课程资料汇总 >>点击查看WUTer计算机专业实验汇总 谨记:纸上得来终觉浅 ...

  3. 武汉理工大学操作系统 课内实验

    文章目录 前言 主要仪器设备及耗材 一.动态分区管理 实验内容描述 实验基本原理与设计 二.磁盘调度 实验内容描述 实验基本原理与设计 总结 前言 操作系统课内实验有两个,验收的学姐人贼好,只看了验收 ...

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

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

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

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

  6. 武汉理工大学数值分析课内实验

    文章目录 前言 主要仪器设备及耗材 一.用C语言实现几个多项式插值的程序.(Lagrange插值.Newton插值) 实验内容描述 实验基本原理与设计 分析与设计 实验结果 二.用C语言实现几个求常微 ...

  7. webservice-UML课内实验报告实验三

    1.webservice 现将网上关于webservice的讲解提炼出来,通过一个最简单使用并且方便的例子,告诉大家什么是webservice. 简单来说,webservice就是远程调用技术,也叫X ...

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

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

  9. 金融应用:信用卡号的合法性验证

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

最新文章

  1. 吴恩达、李飞飞、沈向洋:2021年的人工智能将会如何发展?
  2. python编程爱心-如何用python画爱心
  3. VERY DEEP CONVOLUTIONAL NETWORKS FOR LARGE-SCALE IMAGE RECOGNITION
  4. 网工路由基础(4)EIGRP协议
  5. 浅析epoll – epoll函数深入讲解
  6. laravel框架总结(一) -- 请求和响应
  7. libevent学习笔记
  8. 计算机组成原理课程设计a,计算机组成原理课程设计报告.doc
  9. 计算机科学研究生规划,2019计算机考研备考:计算机科学与技术研究方向及复习规划...
  10. [Linux][Ubuntu]Linux实习常用操作/Debug总结
  11. linux kernel 调度,在Linux中,实时调度_kernel_开发99编程知识库
  12. strace动态调试 php,PHP实现通过strace定位故障原因的方法
  13. (20)FPGA面试题时序设计的实质
  14. WEB标准学习路程之CSS:7.表格,滚动条,打印
  15. 微软 服务器系统,微软正在开发Windows Server 2022服务器系统
  16. python类与对象的内置函数大全(BIF)
  17. 低压差线性稳压器MPQ2013A-AEC1品牌MPS国产替代
  18. 「干货分享」我所在团队的竞品分析模板--附下载
  19. Ubuntu中的Gif动画录制工具
  20. Excel密码解除方法 破解

热门文章

  1. 一个简单的自定义alert方法
  2. C++ windows下判断鼠标点击及获取像素点
  3. 解析原生IP和广播IP
  4. 虚拟桌面分屏_Windows 分屏和虚拟桌面,也能很实用
  5. 骞云云原生运维管理平台7.0版本正式发布
  6. es多个字段排序_如何解决 ES 复杂聚合排序问题(嵌套桶排序)?
  7. Jetson TX2零基础学习(一)——连线、刷机
  8. 新浪微博2012校招笔试题
  9. 中标麒麟B040版本桌面系统root密码破解
  10. Clion源码编辑器的学习与实践