第九届蓝桥杯省赛JAVA语言 C组题解_题5 书号验证

JAVA语言 C组题解_题5 书号验证

    • 题目
    • 解题思路

题目

标题:书号验证

2004年起,国际ISBN中心出版了《13位国际标准书号指南》。
原有10位书号前加978作为商品分类标识;校验规则也改变。
校验位的加权算法与10位ISBN的算法不同,具体算法是:
用1分别乘ISBN的前12位中的奇数位(从左边开始数起),用3乘以偶数位,乘积之和以10为模,10与模值的差值再对10取模(即取个位的数字)即可得到校验位的值,其值范围应该为0~9。

下面的程序实现了该算法,请仔细阅读源码,填写缺失的部分。

public class A
{
static boolean f(String s){
int k=1;
int sum = 0;
for(int i=0; i char c = s.charAt(i);
if(c==’-’ || c==’ ') continue;
sum += ______________________________; //填空
k++;
if(k>12) break;
}
return s.charAt(s.length()-1)-‘0’ == (10-sum % 10)%10;
}
public static void main(String[] args){
System.out.println(f(“978-7-301-04815-3”));
System.out.println(f(“978-7-115-38821-6”));
}
}

注意:只提交空缺的代码,不要抄写已经存在的代码。

解题思路

1、分析代码查看代码缺失的功能。
2、补充未实现的代码。
3、缺失的实现部分为:用1分别乘ISBN的前12位中的奇数位(从左边开始数起),用3乘以偶数位,乘积之和
答案: k%2==0?3*(c-‘0’):(c-‘0’);

//java代码
		static boolean f(String s) {
		int k = 1;//记录第几位
		int sum = 0;//保存和
		for (int i = 0; i < s.length(); i++) {//循环计算前12位数字的和
			char c = s.charAt(i);//截取字符串中的第i位字符
			if (c == '-' || c == ' ')//跳过不是数字的字符
				continue;
			//三元运算符判断奇偶,奇数sum += (c-'0');偶数sum += 3*(c-'0');
			sum += k%2==0?3*(c-'0'):(c-'0'); // 填空
			k++;//计算完毕后k+1
			if (k > 12)
				break;//大于12跳出循环
		}
	//s.charAt(s.length() - 1) - '0'校检位的值
	//(10 - sum % 10) % 10;以10为模,10与模值的差值再对10取模
		return s.charAt(s.length() - 1) - '0' == (10 - sum % 10) % 10;
	}

	public static void main(String[] args) {
		System.out.println(f("978-7-301-04815-3"));
		System.out.println(f("978-7-115-38821-6"));
	}
	}

你可能感兴趣的:(蓝桥杯历史题目)