6-3 数字校验作者 殷伟凤单位 浙江传媒学院
本题要求实现一个函数,校验一个13位正整数号码是否正确。13位号码的最后一位是校验码。通过对前12位数字的加减乘除运算得到一个一位数字,如果和第13位数字相同,表示正确的号码。
1、从最右边第12位开始间隔一位个位数相加,然后乘7。
2、剩下的其余数字相加,然后乘2 。
3、再把两者加起来,除以10取余数
4、和第13位相校验,匹配就正确,不匹配则错误。
裁判测试程序样例:
import java.util.Scanner; public class Main { /* 请在这里填写答案 */ public static void main(String[] args) { Scanner in = new Scanner(System.in); long code = in.nextLong(); boolean checksumResult = checksum(code); if (checksumResult) System.out.println("The checksum of "+code+" is "+ "correct"); else System.out.println("The checksum of "+code+" is "+ "incorrect"); } }
输入样例1:
在这里给出一组输入。例如:
1234567890126
输出样例1:
在这里给出相应的输出。例如:
The checksum of 1234567890126 is correct
输入样例2:
在这里给出一组输入。例如:
2345677654329
输出样例2:
在这里给出相应的输出。例如:
The checksum of 2345677654329 is incorrect
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
public static boolean checksum(long number)
{
long checkcode=number%10;
number=number/10;
long[] nums=new long[12];
int i;
for(i=0;i<12;i++)
{
nums[i]=number%10;
number/=10;
}
long num1=0;
for(i=0;i<12;i+=2)
{
num1+=nums[i];
}
num1*=7;
long num2=0;
for(i=1;i<12;i+=2)
{
num2+=nums[i];
}
num2*=2;
long num=(num1+num2)%10;
if(num==checkcode)
return true;
else
return false;
}