ISBN-号码-vijos
2017-12-03 15:13
274 查看
描述
每一本正式出版的图书都有一个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
样例输入1
0-670-82162-4Copy
样例输出1
RightCopy
样例2
样例输入2
0-670-82162-0Copy
样例输出2
0-670-82162-4Copy
限制
各个测试点1s
来源
NOIP2008复赛原题子夜长河提供
代码:
#include<iostream>
using namespace std;
int main(){
int a[9],b[3];
int i,k,cnt=0,sum=0;
char c[4],key;
for (i=0; i<3; i++) {
cin>>b[i];
cin>>c[cnt];
cnt++;
}
cin>>key;
a[0]=b[0];
a[1]=b[1]/100;
a[2]=b[1]/10%10;
a[3]=b[1]%10;
a[4]=b[2]/10000;
a[5]=b[2]/1000%10;
a[6]=b[2]/100%10;
a[7]=b[2]/10%10;
a[8]=b[2]%10;
for (i=0; i<9; i++) {
sum+=a[i]*(i+1);
}
k=sum%11;
if (k==(key-'0') || (k==10 && key=='X')) {
cout<<"Right";
} else {
cnt=0;
for (i=0; i<9; i++) {
cout<<a[i];
if (i==0 || i==3 || i==8) {
cout<<c[cnt];
cnt++;
}
}
if (k==10){
cout<<"X";
} else {
cout<<k;
}
}
cout<<endl;
return 0;
}
相关文章推荐
- Vijos P1484 ISBN号码
- Vijos P1484-ISBN号码
- Vijos 1484题:ISBN号码
- 【vijos】P1484 ISBN号码
- CCF认证-ISBN号码
- NOIP2008 普及组T1 ISBN号码 解题报告-S.B.S.
- CCF | 201312-2 ISBN号码
- Viojs P1484 ISBN号码
- ISBN 号码(201312_2)
- CCF201312-2 ISBN号码
- 关于ISBN号码的一些解法
- CCF 201312-2 ISBN号码 题解
- 29:ISBN号码
- 1050: 贝贝的ISBN号码(isbn)
- noi-7911-ISBN号码
- CCF CSP试题201312-2 ISBN号码
- CCF之ISBN号码
- CCF认证模拟之ISBN号码
- 201312-2 ISBN号码
- noi-7911-ISBN号码