第九届蓝桥杯省赛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"));
	}
	}
经验分享 程序员 微信小程序 职场和发展