ISBN号码 201312-2

问题描述

每一本正式出版的图书都有一个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号码(包括分隔符“$-$”)。

样例输入1

$0-670-82162-4$

样例输出1

$Right$

样例输入2

$0-670-82162-0$

样例输出2

$0-670-82162-4$

正确解答(Dev-CPP环境)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <iostream>
#include<string>
using namespace std;

int main()
{
string str;cin>>str;
int s=0;int p=1;
for(int i=0;i<str.length()-1;i++){
if(str[i]!='-'){
int t=str[i]-'0';
s+=t*p;
p++;
}
}
int j=str[str.length()-1]-'0';
if(s%11==10&&str[str.length()-1]=='X'){
cout<<"Right"<<endl;return 0;
}else if(s%11==10&&str[str.length()-1]!='X'){
cout<<str.substr(0,12)<<'X'<<endl;return 0;
}
if(j==s%11){
cout<<"Right"<<endl;
}else{
cout<<str.substr(0,12)<<s%11<<endl;
}
return 0;
}

不完全正确解答(Dev-CPP环境,仅70分)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#include <stdio.h>
#include <stdlib.h>

int main(){
char isbn[15]={0};
int ic=0,i=0,temp=0,cnt=1;
scanf("%s",isbn);
ic=(int)(isbn[0]-'0');
for(i=2;i<=10;i++){
if(isbn[i]=='-'){
continue;
}else{
cnt++;
temp=(int)(isbn[i]-'0');
}
ic=ic+temp*cnt;
}
ic=ic%11;
if(isbn[12]=='X'&&ic==10){
printf("Right");
}else if((char)(ic+'0')==isbn[12]){
printf("Right");
}else{
isbn[12]=(char)(ic+'0');
//printf("%c\n",isbn[12]);
printf("%s",isbn);
}

return 0;
}