• 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;
    	}
    }
    
    
  • 相关阅读:
    C++指针
    Linux Ubuntu常用终端命令
    java-JDBC-Oracle数据库连接
    HDU 1890 区间反转
    Hdu-3487 Splay树,删除,添加,Lazy延迟标记操作
    UVa 10088
    UVa10025-The ? 1 ? 2 ? ... ? n = k problem
    UVa10023手动开大数平方算法
    UVa 10007
    点的双联通+二分图的判定(poj2942)
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13077623.html
Copyright © 2020-2023  润新知