蓝桥杯练习题

题目:每---本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、1位识别码和3位分隔符,其规定格式如"x-xXX-XXXxx-x",其中符号"-"是分隔符(键盘上的减号),最后---位是识别码,例如O-670-82162-4就是一个标准的ISBN码。ISBN码的首位数字表示书籍的出版语言,例如О代表英语;第---个分隔符"-"之后的三位数字代表出版社,例如670代表维京出版社;第二个分隔之后的五位数字代表该书在出版社的编号;最后---位为识别码。

识别码的计算方法如下:

首位数字乘以1加上次位数字乘以2......以此类推,用所得的结果mod 11,所得的余数即为识别码,如果余数为10,则识别码为大写字母×。例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对067082162这9个数字,从左至右,分别乘以1,2,...,9,再求和,即O×1+6×2+......+2×9=158,然后取158 mod 11的结果4作为识别码。你的任务是编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出Right;如果错误,则输出你认为是正确的ISBN号码。

实现思路:

1.首先,通过Scanner类从控制台读取用户输入的ISBN号。

2.去除出版编号中的所有"_"。

3.初始化一个累加器sum为0。

4.使用for循环遍历ISBN号中的每个数字字符,除了最后一个字符。将每个数字字符转换为整数,乘以一个递增的k(从1开始),然后将结果加到sum中。

5.根据sum的值计算校验码。如果sum除以11的余数是10,校验码是"X";否则,校验码是sum除以11的余数。

6.获取原始的校验码,即ISBN号中的最后一个字符。

7.如果计算出的校验码与原始校验码相同,则输出"Right",表示ISBN号有效。

8.如果不同,则输出修正后的ISBN号(原始字符串除了最后一个字符之外的所有字符,加上计算出的校验码)。

java 复制代码
package com.ztt.Demo01;

import java.util.Scanner;
public class demo02 {

	public static void main(String[] args) {
		try(Scanner in = new Scanner(System.in)){
			String isbn=in.nextLine();
			
			//去除出版编号中的所有"_"
			String isbnNumberStr = isbn.replace("-", "");
			
			//遍历除数校验码(最后一位)以外的所有字符
			int sum=0;
			for(int i=0,k=1;i<isbnNumberStr.length()-1;i++,k++) {
				
				int n=Integer.parseInt(String.valueOf(isbnNumberStr.charAt(i)));//将字符转换为字符串,获取字符串isbnNumberStr中的第i个字符,将字符串转换为整数。
				
				sum += n * k;
				
			}
			System.out.println(sum);
			
			//根据累加值,计算校验码
			String validateCode = String.valueOf(sum % 11==10 ? "X" :sum % 11);
			
			//获取原始的校验码
			String last=String.valueOf(isbnNumberStr.charAt(isbnNumberStr.length()-1));
			
			if(validateCode.equals(last)) {
				System.out.println("Right");
			}else {
				System.out.println(isbn.substring(0,isbn.length()-1) + validateCode);
			}
		}

	}

}

运行结果:

java 复制代码
0-670-82162-4
158
Right
相关推荐
Daniel 大东2 分钟前
idea 解决缓存损坏问题
java·缓存·intellij-idea
wind瑞9 分钟前
IntelliJ IDEA插件开发-代码补全插件入门开发
java·ide·intellij-idea
HappyAcmen9 分钟前
IDEA部署AI代写插件
java·人工智能·intellij-idea
马剑威(威哥爱编程)14 分钟前
读写锁分离设计模式详解
java·设计模式·java-ee
鸽鸽程序猿15 分钟前
【算法】【优选算法】前缀和(上)
java·算法·前缀和
修道-032316 分钟前
【JAVA】二、设计模式之策略模式
java·设计模式·策略模式
九圣残炎21 分钟前
【从零开始的LeetCode-算法】2559. 统计范围内的元音字符串数
java·算法·leetcode
当归102434 分钟前
若依项目-结构解读
java
hlsd#1 小时前
关于 SpringBoot 时间处理的总结
java·spring boot·后端
iiiiiankor1 小时前
C/C++内存管理 | new的机制 | 重载自己的operator new
java·c语言·c++