蓝桥杯(java)个人赛真题:书号验证

书号验证

			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; i12) 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分别乘ISBN的前12位中的奇数位(从左边开始数起),用3乘以偶数位
至于分析方法,因为代码内只有一个for循环,而却没有算上面的代码,再或者结合变量名sum看出代表的是和,再者从后往前看,(10-sum % 10)%10这行代码与之前题目的描述 :乘积之和以10为模,10与模值的差值再对10取模
所以很确定得到sum代表用 :1分别乘ISBN的前12位中的奇数位(从左边开始数起),用3乘以偶数位

package Lqb;

public class Text31 {
	public static void main(String[] args) {
		System.out.println(f("978-7-301-04815-3"));
		System.out.println(f("978-7-115-38821-6"));
	}
	static boolean f(String s){
		int k=1;
		int sum = 0;
		for(int i=0; i12) break; 
		}
		return s.charAt(s.length()-1)-'0' == (10-sum % 10)%10;
	}
}

你可能感兴趣的:(JAVA,蓝桥杯习题,算法,书号验证,蓝桥杯真题,蓝桥杯省赛,JavaC组)