数字校验
本题要求实现一个函数,校验一个13位正整数号码是否正确。13位号码的最后一位是校验码,通过对前12位数字的的加减乘除运算得到一个一位数字,如果和第13位数字相同,表示正确的号码。
1、从最右边第12位开始间隔一位个位数相加,然后乘7。
2、剩下的其余数字相加,然后乘2。
3、再把两者加起来,除以10取余数。
4、和第13位相校验,匹配就正确,不匹配则错误。
输入样例1:
在这里给出一组输入。例如:
1234567890126
输出样例1:
在这里给出一组输出。例如:
The checksum of 1234567890126 is correct
输入样例2:
2345677654329
输出样例2:
The checksum of 2345677654329 is incorrect
下面给出具体的代码:
方法一:通过数组实现
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
long code=sc.nextLong();
boolean checksumResult=checksum(code);
if(checksumResult)
System.out.println("correct");