时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 白银 Silver
题目描述 Description

每一本正式出版的图书都有一个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号码。

输入描述 Input Description

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

输出描述 Output Description

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

样例输入 Sample Input

输入1:

0-670-82162-4

输入2:

0-670-82162-0

样例输出 Sample Output

输出1:

Right

输出2:

0-670-82162-4

来源 source

2008年NOIP全国联赛普及组

#include<iostream>
#include<cstdio>
#include<cstring> using namespace std; string ISBN;
int i,j,k;
int main()
{
int z=;
cin>>ISBN;
int len=ISBN.length();
for(i=;i<len-;++i)
{
if(ISBN[i]>=''&&ISBN[i]<='')
{
z+=(ISBN[i]-)*(++k);
}
}
int ans=z%;
if((ans!=&&ans==ISBN[len-]-)||(ans==&&ISBN[len-]=='X')) cout<<"Right";
else {
for(i=;i<len-;++i) cout<<ISBN[i];
if(ans!=)
cout<<ans;
else cout<<"X";
}
cout<<endl;
}

最新文章

  1. Windows下Go语言的环境搭建
  2. 在Linux/Windows系统上编辑/etc/hosts文件
  3. 高性能PHP支持静态类型
  4. web前端开发框架搜集
  5. Intersection of Two Linked Lists(java)
  6. 初步STL集装箱List
  7. jquery 分页控件2
  8. GetLastError() 返回值含义
  9. android 中ImageButton按下改变背景图片的效果
  10. 消息队列NetMQ 原理分析3-命令产生/处理和回收线程
  11. 【CF 678F】Lena and Queries
  12. cdoj 1092 韩爷的梦
  13. 018-继承-OC笔记
  14. Eclipse 从git导入maven多模块项目
  15. LintCode 521.去除重复元素
  16. Java 中各种空(&quot;&quot;、\u0000、null)的区别?
  17. Linux下ps -ef 和 ps aux的区别
  18. 模型层model layer
  19. Node.js从入门到实战ECMAScript6一页纸总结(很大的一页纸)
  20. Linux安装系统选择 日报 18/06/23

热门文章

  1. _beginThreadex的用法
  2. LeetCode: 575 Distribute Candies(easy)
  3. 简易DIV垂直居中阴影层笼罩JS实现
  4. Golang : flag 包简介
  5. dos生成目录树
  6. POJ3463【次短路】
  7. 【渗透测试】如何使用burpsuite对特殊密码进行爆破
  8. 搭建 CDH 版本hive
  9. [Noip模拟题]统计方案​
  10. Java - 怎么通过环境变量来切换jdk版本