CCF认证 2013-12-2 ISBN号码
来源:互联网 发布:c语言开根号函数 编辑:程序博客网 时间:2024/06/05 08:34
(如有雷同,纯属巧合)
问题描述
每一本正式出版的图书都有一个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号码。
识别码的计算方法如下:
首位数字乘以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
代码内容:
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std ;
int main()
{
string s ;
cin >> s ;
int sum = 0;
int j = 1 ;
char a ;
for(int i=0;i<s.size()-1;i++)
{
if(isdigit(s[i]))
sum += j*(s[i]-'0') ;//数字就乘以j;字符转换成数字
else
continue ;
j++ ;
}
if(sum%11 == 10)
a = 'X' ;
else
a = sum%11 +'0' ;//数字转换为字符
if(a == s[s.size()-1])
{
cout << "Right" ;
}
else
{
s[s.size()-1] = a ;
cout << s ;
}
return 0 ;
}
#include<cstring>
#include<cstdio>
using namespace std ;
int main()
{
string s ;
cin >> s ;
int sum = 0;
int j = 1 ;
char a ;
for(int i=0;i<s.size()-1;i++)
{
if(isdigit(s[i]))
sum += j*(s[i]-'0') ;//数字就乘以j;字符转换成数字
else
continue ;
j++ ;
}
if(sum%11 == 10)
a = 'X' ;
else
a = sum%11 +'0' ;//数字转换为字符
if(a == s[s.size()-1])
{
cout << "Right" ;
}
else
{
s[s.size()-1] = a ;
cout << s ;
}
return 0 ;
}
0 0
- CCF认证 2013-12-2 ISBN号码
- CCF认证-ISBN号码
- CCF认证 201312-2 ISBN号码
- CCF计算机软件能力认证试题练习201312-2-ISBN号码
- CCF认证模拟之ISBN号码
- CCF认证ISBN号码80分
- CCF 201312-2ISBN号码
- CCF-ISBN号码-201312-2
- [CCF]201312-2 ISBN号码
- CCF | 201312-2 ISBN号码
- CCF-201312-2-ISBN号码
- CCF 201312-2 ISBN号码
- CCF 201312-2 ISBN号码
- 201312-2 ISBN号码 ccf
- CCF-CAP 201312-2 ISBN号码 答案
- CCF 201312-2 ISBN号码 题解
- CCF CSP试题201312-2 ISBN号码
- CCF CSP 201312-2 ISBN号码
- 【mysql】常用命令(持续补充)
- 《粟裕回忆录》之节选
- 在VirtualBox中的CentOS 6.3下安装VirtualBox增强包
- caffe 运行出错的问题记录
- PAT (Basic Level) Practise (中文)1007素数对猜想 (20)
- CCF认证 2013-12-2 ISBN号码
- J2EE常用名词
- 操作系统--进程与线程
- PHP基础知识文件的引入
- HDU 1711 Number Sequence
- 学了一周的安卓,写了个简单的 种子搜索器app
- 学习jsp课程学堂笔记1
- mapreduce系列(1)---入门案例深入分析以及切片源码简析
- 关于假如有Thread1、Thread2、Thread3、Thread4四条线程分别统计C、D、E、F四个盘的大小,所有线程都统计完毕交给Thread5线程去做汇总,应当如何实现?