蓝桥杯练习题

题目:每---本正式出版的图书都有一个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
相关推荐
Bonne journée12 分钟前
‌在Python中,print(f‘‘)是什么?
java·开发语言·python
2402_8575893632 分钟前
新闻推荐系统:Spring Boot框架详解
java·spring boot·后端
2401_8576226634 分钟前
新闻推荐系统:Spring Boot的可扩展性
java·spring boot·后端
小懒编程日记39 分钟前
【数据结构与算法】B树
java·数据结构·b树·算法
Y_3_71 小时前
【回溯数独】有效的数独(medium)& 解数独(hard)
java·数据结构·windows·算法·dfs·回溯
RangoLei_Lzs1 小时前
C++模版SFIANE应用踩的一个小坑
java·开发语言·ui
北极无雪1 小时前
Spring源码学习(拓展篇):SpringMVC中的异常处理
java·开发语言·数据库·学习·spring·servlet
VXbishe1 小时前
(附源码)基于springboot的“我来找房”微信小程序的设计与实现-计算机毕设 23157
java·python·微信小程序·node.js·c#·php·课程设计
YONG823_API2 小时前
电商平台数据批量获取自动抓取的实现方法分享(API)
java·大数据·开发语言·数据库·爬虫·网络爬虫
扬子鳄0082 小时前
java注解的处理器
java