第九届蓝桥杯省赛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<s.length(); 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")); } }