zoukankan      html  css  js  c++  java
  • Java实现第九届蓝桥杯书号验证

    书号验证

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

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

    PS:
    这类填空题都是可找技巧的,经验足够前提下,题目认真分析完,发现代码不长,直接就很容易能看出缺失的是:
    缺:用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; i<s.length(); i++){
    			char c = s.charAt(i);
    			if(c=='-' || c==' ') continue;
    			sum +=(c - '0') * (k % 2 == 0?3:1);  //填空
    			k++;
    			if(k>12) break; 
    		}
    		return s.charAt(s.length()-1)-'0' == (10-sum % 10)%10;
    	}
    }
    
    
  • 相关阅读:
    关于树论【动态树问题(LCT)】
    caioj1462: 【EXKMP】回文串
    Node.js 文件上传 cli tools
    VuePress & Markdown Slot
    npm config set registry
    Front End Frameworks Trending 2021
    如何使用 VuePress 搭建一个 element-ui 风格的文档网站
    Semantic Pull Requests All In One
    [POJ2559]Largest Rectangle in a Histogram
    [POJ3253]Fence Repair
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13077622.html
Copyright © 2011-2022 走看看