题目描述
生成13位条形码 Ean-13码规则:第十三位数字是前十二位数字经过计算得到的校验码。 例如:690123456789 计算其校验码的过程为: 前十二位的奇数位和6+0+2+4+6+8=26 前十二位的偶数位和9+1+3+5+7+9=34 将奇数和与偶数和的三倍相加26+34*3=128 取结果的个位数:128的个位数为8 用10减去这个个位数10-8 所以校验码为2 (注:如果取结果的个位数为0,那么校验码不是为10(10-0=10),而是0) 实现方法ean13()计算验证码,输入12位条码,返回带验证码的条码。 例:输入:692223361219输出:6922233612192
基本思路
首先要使用Scanner接收一个十二位的整数,十二位整数要用long型。
若想计算奇数和与偶数和,就必须把这个十二位数的每一位都单独取出来,取出之后可以用数组存放,之后遍历数组计算奇数和与偶数和。
代码实现
package HomeWork;
import java.util.Scanner;
/**
* @Author: lly
* @Description: 生成13位条形码
* Ean-13码规则:第十三位数字是前十二位数字经过计算得到的校验码。
* 例如:690123456789
* 计算其校验码的过程为:
* 前十二位的奇数位和6+0+2+4+6+8=26
* 前十二位的偶数位和9+1+3+5+7+9=34
* 将奇数和与偶数和的三倍相加26+34*3=128
* 取结果的个位数:128的个位数为8
* 用10减去这个个位数10-8
* 所以校验码为2
* (注:如果取结果的个位数为0,那么校验码不是为10(10-0=10),而是0)
* 实现方法ean13()计算验证码,输入12位条码,返回带验证码的条码。
* 例:输入:692223361219输出:6922233612192
* @DateTime: 2022/7/20 20:51
**/
public class Work27 {
public static void main(String[] args) {
long[] nums = new long[20];
Scanner sc= new Scanner(System.in);
System.out.print("请输入一串十二位数:");
long code = sc.nextLong();
int index = 0;
int count=0;
int evenSum=0;
int oddSum=0;
for ( long i =code ;i>0;i/=10 ,index++){
long a = i%10;
nums[index]=a;
count++;
}
for (int i = 0; i <= count; i++) {
if (nums[i]%2==0){
evenSum+=nums[i];
}else {
oddSum+=nums[i];
}
}
int num3= evenSum+oddSum*3;
int gw = num3%10;
int checkCode = 10-gw;
long okCode = code*10+checkCode;
System.out.print("生成的条形码为:");
System.out.println(okCode);
}
}