PTA 作业一 两分钟学会JAVA语言 详细讲解 6-3 数字校验本题要求实现一个函数,校验一个13位正整数号码是否正确。13位号码的最后一位是校验码。

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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大葫芦臂围40狂敲代码

你的鼓励是前进的动力,有求必答

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值