ISBN 号码(数组与字符串)
题目描述
每一本正式出版的图书都有一个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 号码(数组与字符串)相关推荐
- 【洛谷新手村】简单字符串 p1055 ISBN号码
p1055 ISBN号码[传送门] 算法标签什么的: 思路:直接以字符串的形式读入这一串数字,然后for循环对字符串进行处理,字符串中的数字存进数组中(如果是X,存为10):然后再根据要求判断是否是正 ...
- 洛谷 P1055 ISBN号码【字符串+模拟】
P1055 ISBN号码 题目描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其 ...
- 【CSP201312-2】ISBN号码,字符串,简单模拟
problem 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISB ...
- 【p081】ISBN号码
Time Limit: 1 second Memory Limit: 50 MB [问题描述] 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定 ...
- 信息学奥赛一本通 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 号码 [题目考点] ...
- CCF201312-2 ISBN号码
问题描述: 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码 ...
- csp试题2:ISBN号码
csp试题2:ISBN号码 题目 分析 代码 总结 题目 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如" ...
- [XDOJ] ISBN号码
标题 ISBN号码类别 字符串处理时间限制 1S内存限制 256Kb问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如" ...
- CCF真题之ISBN号码
201312-2 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其中符号& ...
最新文章
- STL中的双向队列deque
- python输入字符串从大到小排列_567. 字符串的排列(Python)
- golang 开发 Struct 转换成 map 两种方式比较
- Ubuntu使用技巧(三), 硬盘安装Linux(UEFI)
- (转微软网站)如何安装 Microsoft Dynamics CRM 4.0 具有最低必需权限
- 史上最强大型分布式架构详解:高并发+数据库+缓存+分布式+微服务+秒杀
- 天猫双11星秀猫官方周边开售 从设计到生产用时1个月
- unity ui框架_[教程汇总+持续更新]Unity从入门到入坟——收藏这一篇就够了
- 游戏巨头齐聚 Unite Shanghai 2019,揭秘爆款游戏制作精彩亮点!
- RSAC|苹果设备的最大威胁是逆向后重部署的恶意软件
- Coolite服务端方法调用与Web.Config配置
- win98万能显卡驱动_万能显卡驱动下载
- 米家扫地机器人按键没反应_米家扫地机器人1S测评:性能暴增40%,全面提升带来极佳体验...
- 伊诺伊香槟分校计算机世界排名,2020年伊利诺伊大学香槟分校QS世界排名
- SVM与K-Means
- SkeyeVSS实现监控摄像头进行网页WEB和微信、手机无插件直播点播解决方案
- 如何解决独立站多渠道客户沟通难题?这款跨境电商插件一定要知道!
- hadoop-集群及组件
- 渗透测试的目标、思路
- PPT文档如何快速复制粘贴幻灯片