题目描述
每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、1位识别码和3位分隔符,其规定格式如x-xxx-xxxxx-x,其中符号-就是分隔符(键盘上的减号),最后一位是识别码,例如0-670-82162-4就是一个标准的ISBN码。ISBN码的首位数字表示书籍的出版语言,例如0代表英语;第一个分隔符-之后的三位数字代表出版社,例如670代表维京出版社;第二个分隔符后的五位数字代表该书在该出版社的编号;最后一位为识别码。

识别码的计算方法如下:

首位数字乘以1加上次位数字乘以2……以此类推,用所得的结果 mod11,所得的余数即为识别码,如果余数为10,则识别码为大写字母X。例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对067082162这9个数字,从左至右,分别乘以1,2,…,9再求和,即0×1+6×2+……+2×9=158,然后取158mod11的结果44作为识别码。

你的任务是编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出Right;如果错误,则输出你认为是正确的ISBN号码。

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

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

输入输出样例
输入
0-670-82162-4
输出
Right
输入
0-670-82162-0
输出
0-670-82162-4

重要的是如何处理
-符号输入

#include<stdio.h>
#include<iostream>
using namespace std;
int main(){int i,n=1,t=0;char a[15],b;cin>>a;for(int i=0;i<11;i++){if(a[i]!='-'){//不是-字符时进行操作t+=(a[i]-'0')*n;//-'0'是因为a是char类型,要根据ASCLL码,用数字计算就得将每一个数字型char-数字0的ASCLL码。 n++;//   cout<<t<<endl;//查看分别乘1--9的和; }}if(t%11==10){//数字乘以1加上次位数字乘以2……以此类推对11取余b='X';//取余等于10}else{b=t%11+'0';//加上0的ASCLL码}//判断前面的计算是否等于最后一位数if(b==a[12]){cout<<"Right";}else{a[12]=b;cout<<a;}return 0;
}

减’0’ 是因为a是char类型,要根据ASCLL 码,用数字计算就得将每一个数字型char减数字0的ASCLL码。

建议查找int型转换char型文章

#include <stdio.h>
int main() {int a1, a2, a3;char b, a4;scanf("%d-%d-%d-%c", &a1, &a2, &a3, &a4);int ans1 = 0;ans1 = a1 * 1 + a2 / 100 * 2 + a2 % 100 / 10 * 3 + a2 % 10 * 4 +a3 / 10000 * 5 + a3 % 10000 / 1000 * 6 + a3 % 1000 / 100 * 7 +a3 % 100 / 10 * 8 + a3 % 10 * 9;int ans = 0;ans = ans1 % 11;if (ans == 10) {b = 'X';} else {b = ans + '0';}if (b == a4)printf("Right");else {a4 = b;printf("%d-%03d-%05d-%c", a1, a2, a3, b);}return 0;
}

建议查找int型转换char型文章

ISBN 号码(数组与字符串)相关推荐

  1. 【洛谷新手村】简单字符串 p1055 ISBN号码

    p1055 ISBN号码[传送门] 算法标签什么的: 思路:直接以字符串的形式读入这一串数字,然后for循环对字符串进行处理,字符串中的数字存进数组中(如果是X,存为10):然后再根据要求判断是否是正 ...

  2. 洛谷 P1055 ISBN号码【字符串+模拟】

    P1055 ISBN号码 题目描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其 ...

  3. 【CSP201312-2】ISBN号码,字符串,简单模拟

    problem 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISB ...

  4. 【p081】ISBN号码

    Time Limit: 1 second Memory Limit: 50 MB [问题描述] 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定 ...

  5. 信息学奥赛一本通 1942:【08NOIP普及组】ISBN号码 | OpenJudge NOI 1.7 29:ISBN号码 | 洛谷 P1055 [NOIP2008 普及组] ISBN 号码

    [题目链接] ybt 1942:[08NOIP普及组]ISBN号码 OpenJudge NOI 1.7 29:ISBN号码 洛谷 P1055 [NOIP2008 普及组] ISBN 号码 [题目考点] ...

  6. CCF201312-2 ISBN号码

    问题描述: 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码 ...

  7. csp试题2:ISBN号码

    csp试题2:ISBN号码 题目 分析 代码 总结 题目 问题描述       每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如" ...

  8. [XDOJ] ISBN号码

    标题 ISBN号码类别 字符串处理时间限制 1S内存限制 256Kb问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如" ...

  9. CCF真题之ISBN号码

    201312-2 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其中符号& ...

最新文章

  1. STL中的双向队列deque
  2. python输入字符串从大到小排列_567. 字符串的排列(Python)
  3. golang 开发 Struct 转换成 map 两种方式比较
  4. Ubuntu使用技巧(三), 硬盘安装Linux(UEFI)
  5. (转微软网站)如何安装 Microsoft Dynamics CRM 4.0 具有最低必需权限
  6. 史上最强大型分布式架构详解:高并发+数据库+缓存+分布式+微服务+秒杀
  7. 天猫双11星秀猫官方周边开售 从设计到生产用时1个月
  8. unity ui框架_[教程汇总+持续更新]Unity从入门到入坟——收藏这一篇就够了
  9. 游戏巨头齐聚 Unite Shanghai 2019,揭秘爆款游戏制作精彩亮点!
  10. RSAC|苹果设备的最大威胁是逆向后重部署的恶意软件
  11. Coolite服务端方法调用与Web.Config配置
  12. win98万能显卡驱动_万能显卡驱动下载
  13. 米家扫地机器人按键没反应_米家扫地机器人1S测评:性能暴增40%,全面提升带来极佳体验...
  14. 伊诺伊香槟分校计算机世界排名,2020年伊利诺伊大学香槟分校QS世界排名
  15. SVM与K-Means
  16. SkeyeVSS实现监控摄像头进行网页WEB和微信、手机无插件直播点播解决方案
  17. 如何解决独立站多渠道客户沟通难题?这款跨境电商插件一定要知道!
  18. hadoop-集群及组件
  19. 渗透测试的目标、思路
  20. PPT文档如何快速复制粘贴幻灯片

热门文章

  1. 在uniapp的webview组件引用的网页内如何实时定位
  2. 股指期货与恒生指数期货的区别是什么
  3. Unity实例开发-AlienShooter(一)
  4. python复制word到粘贴板_python3+PyQt5实现使用剪贴板做复制与粘帖示例
  5. 安卓手机软件测试耗电量
  6. MySQL性能优化之降龙十八掌
  7. ubtunu打开firefox_虚拟机Ubuntu下安装Firefox浏览器
  8. 你知道PPT免费翻译软件有哪些吗?
  9. 【报告分享】中国K12在线辅导行业总结和趋势洞察2021-易观智库(附下载)
  10. bugku 白哥的鸽子