CCF CSP 201312-2:ISBN号码


CCF CSP 2013年第二题:ISBN号码

问题

问题描述

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

识别码的计算方法如下:

首位数字乘以1加上次位数字乘以2……以此类推,用所得的结果mod 11,所得的余数即为识别码,如果余数为10,则识别码为大写字母X。例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对067082162这9个数字,从左至右,分别乘以1,2,…,9,再求和,即0×1+6×2+……+2×9=158,然后取158 mod 11的结果4作为识别码。

编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出“Right”;如果错误,则输出是正确的ISBN号码。

输入格式

  输入只有一行,是一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。

输出格式

  输出一行,假如输入的ISBN号码的识别码正确,那么输出“Right”,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”)。

样例输入

0-670-82162-4

样例输出

Right

样例输入

0-670-82162-0

样例输出

0-670-82162-4

解题思路分析

这道题是一道字符串题目主要考察字符串操作,而对数学能力几乎没有考察,基本思路是,将这个字符串读入然后将其按照位来进行相应的操作就好了。基本考察的就是字符串的转换。

通过的代码

import java.util.ArrayList;
import java.util.Scanner;
/*代码已经通过测试*/
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        /*只需要一次读入*/
        String string = sc.nextLine();
        char[] charArray = string.toCharArray();
        ArrayList<Character> arrayList = new ArrayList<Character>();
        /*按照套路操作字符串*/
        for (char letter:charArray){
            if (letter!='-'){
                arrayList.add(letter);
            }
        }
        int sum =0;
        for (int i=0;i<9;i++){
            sum+=(i+1)*Character.getNumericValue(arrayList.get(i));
        }

        if (sum%11 ==
                (arrayList.get(9)=='X' ? 10 : Character.getNumericValue(arrayList.get(9)))){
            System.out.println("Right");
        }else{
            arrayList.remove(9);
            if (sum%11!=10){
                arrayList.add((char)(sum%11+'0'));
            }else{
                arrayList.add('X');
            }
            arrayList.add(1,'-');
            arrayList.add(5,'-');
            arrayList.add(11,'-');
            StringBuilder stringBuilder = new StringBuilder(arrayList.size());
            for (char a:arrayList){
                stringBuilder.append(a);
            }
            System.out.println(stringBuilder.toString());
        }


    }
}

总结

java String 转 char[]

String string = sc.nextLine();
char[] charArray = string.toCharArray();

java char 转 int

char a = '0'
int b = Character.getNumericValue(a)

java char[] 转 String

StringBuilder stringBuilder = new StringBuilder(arrayList.size());
for (char a:arrayList){
    stringBuilder.append(a);
}
System.out.println(stringBuilder.toString());

ascii 原理下面两个

java int 转 char

int a = 6;
char b = (char)(a+'0');

java char 转 int

char a = '9';
int b = a - '0';

推荐阅读

java - Best way to convert ArrayList of Character to String - Stack Overflow

int型一位数与char类型间的相互转化_朱茂强的博客-CSDN博客


文章作者: Cyber-Peng
版权声明: 本博客所有文章除特別声明外,均采用 CC BY-ND 4.0 许可协议。转载请注明来源 Cyber-Peng !
 上一篇
CCF CSP 201312-3 第三题 最大的矩形 CCF CSP 201312-3 第三题 最大的矩形
CCF CSP 201312-3 第三题 最大的矩形问题描述  在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1 ≤ i ≤ n)个矩形的高度是hi。这n个矩形构成了一个直方图。例如,下图中六个矩形的高度就分别是3, 1, 6,
2020-02-26
下一篇 
Hexo一键部署并备份Powershell脚本书写 Hexo一键部署并备份Powershell脚本书写
Hexo一键部署并备份Powershell脚本书写最近玩Hexo每次写完博客都要一顿操作猛如虎来发表文章,一般人都会比较厌烦这些比较麻烦的步骤,本篇博客就是介绍如何书写一键部署脚本 为啥用PowershellPowershell是巨硬推出的
  目录