NOIP2008 普及组T1 ISBN号码 解题报告-S.B.S.
2016-05-02 16:44
696 查看
题目描述
每一本正式出版的图书都有一个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.in只有一行,是一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。
输出格式:
输出文件isbn.out共一行,假如输入的ISBN号码的识别码正确,那么输出“Right”,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”)。
输出样例#1:
------------------------------------我是分割线----------------------------------------------------------------
水题,纯模。
View Code
每一本正式出版的图书都有一个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.in只有一行,是一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。
输出格式:
输出文件isbn.out共一行,假如输入的ISBN号码的识别码正确,那么输出“Right”,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”)。
输入输出样例
输入样例#1:【输入样例1】 0-670-82162-4 【输入样例2】 0-670-82162-0
输出样例#1:
【输出样例1】 Right 【输出样例2】 0-670-82162-4
说明
2008普及组第一题------------------------------------我是分割线----------------------------------------------------------------
水题,纯模。
#include<iostream> #include<cstdio> #include<cstring> using namespace std; int x=1,sum=0; string a; int main() { getline(cin,a); for(int i=0;i<=10;i++) if(i!=1&&i!=5) { sum+=(a[i]-48)*x; x++; } sum=sum%11; if(sum==10) { if(a[12]==88) cout<<"Right"; else { for(int j=0;j<=10;j++) if(j==1||j==5) cout<<"-"; else cout<<a[j]-48; cout<<"-X"; } } else { if(sum==a[12]-48) cout<<"Right"; else { for(int j=0;j<=10;j++) if(j==1||j==5) cout<<"-"; else cout<<a[j]-48; cout<<"-"<<sum; } } return 0; }
View Code
相关文章推荐
- NOIP2008 普及组T2 排座椅 解题报告-S.B.S
- NOIP2008提高组火柴棒等式(模拟)——yhx
- uva 11134 fabled rooks (贪心)——yhx
- NOIP2008提高组(前三题) -SilverN
- uva 11054 wine trading in gergovia (归纳【好吧这是我自己起的名字】)——yhx
- uva 1606 amphiphilic carbon molecules【把缩写写出来,有惊喜】(滑动窗口)——yhx
- uva133-S.B.S.
- uva 120 stacks of flapjacks ——yhx
- uva 1605 building for UN ——yhx
- linux 内核参数图解
- DTO概念
- Uva10082 WERTYU -S.B.S.
- Quicksum-S.B.S.
- 326. Power of Three
- NOIP2014提高组 DAY1 -SilverN
- NOIP2013普及组 -SilverN
- Java InputStream、String、File相互转化
- UVa 11292 Dragon of Loowater
- UVa 839 Not so Mobile
- Quicksum -SilverN