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;
    	}
    }
    
    
  • 相关阅读:
    Oracle查看和删除database link
    时间类型数据使用between ...and ..语句条件查询时应注意的问题
    ORA-01031:权限不足的问题
    ORA-01031:权限不足
    oracle常用命令之tnsping
    oracle数据库tns配置方法详解
    Oracle跨库操作实现
    数据库中Schema(模式)概念的理解
    数据库中的Schema是什么?
    调用全局api(接口)
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13077623.html
Copyright © 2011-2022 走看看