题目原文
试题编号: | 201312-2 |
试题名称: | ISBN号码 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: |
问题描述
每一本正式出版的图书都有一个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号码(保证输入符合ISBN号码的格式要求)。
输出格式
输出一行,假如输入的ISBN号码的识别码正确,那么输出“Right”,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”)。
样例输入
0-670-82162-4
样例输出
Right
样例输入
0-670-82162-0
样例输出
0-670-82162-4
|
题目大意:
挺水的题目。给你13个字符作为IBSN号码,形如“x-xxx-xxxxx-x”,验证前9个“x”,第n个“x”乘n(n为1,,2,3...9),累和记为sum,如果sum%11结果为第10个“x”,则输出“Right”,否则输出应有的余数(顺带把前9个数字和2个“-”也输出)。
解题思路:
将输入的字符放入ISBN数组,遍历前0~10共11位,如果不是“-”,就减去48(1的ASCII码为49),用差值作为实际数字,乘相应的n。累和模11。最后注意取余后结果为10,则记作“X”。
AC代码
1 #include <iostream> 2 #include <stdio.h> 3 #include<cstring> 4 char ISBN[100]; 5 int main() 6 { 7 gets(ISBN); 8 int sum = 0; 9 int flag = 1; 10 for(int i = 0; i < 11; i ++) 11 { 12 if(ISBN[i] == '-') 13 continue; 14 sum += flag * (ISBN[i] - 48); 15 flag ++; 16 } 17 if( (sum % 11 == 10 && ISBN[12] == 'X')) 18 printf("Right "); 19 else if((sum % 11 == (ISBN[12] - 48))) 20 printf("Right "); 21 22 else 23 { 24 for(int i = 0; i < 12; i ++) 25 printf("%c", ISBN[i]); 26 if(sum % 11 == 10) 27 printf("X "); 28 else 29 printf("%c ", sum % 11 + 48); 30 } 31 }
附录
第一次提交50分,忘记了“X”。
1 #include <iostream>
2 #include <stdio.h>
3 #include<cstring>
4 char ISBN[15];
5 int main()
6 {
7 // while(gets(ISBN) != EOF){
8 gets(ISBN);
9 // printf("%d
", ISBN[0]);
10 // printf("%d
", ISBN[0] - 48);
11 int sum = 0;
12 int flag = 1;
13 for(int i = 0; i < 11; i ++)
14 {
15 if(ISBN[i] == '-')
16 continue;
17 sum += flag * (ISBN[i] - 48);
18 flag ++;
19 }
20 if(sum % 11 == (ISBN[12] - 48))
21 printf("Right
");
22 else
23 {
24 for(int i = 0; i < 12; i ++)
25 printf("%c", ISBN[i]);
26 printf("%c
", sum % 11 + 48);
27 }
28 }
第二次提交80分,只把错误的改了,判断“Right”的时候没有考虑“X”。
1 #include <iostream> 2 #include <stdio.h> 3 #include<cstring> 4 char ISBN[15]; 5 int main() 6 { 7 // while(gets(ISBN) != EOF){ 8 gets(ISBN); 9 // printf("%d ", ISBN[0]); 10 // printf("%d ", ISBN[0] - 48); 11 int sum = 0; 12 int flag = 1; 13 for(int i = 0; i < 11; i ++) 14 { 15 if(ISBN[i] == '-') 16 continue; 17 sum += flag * (ISBN[i] - 48); 18 flag ++; 19 } 20 if(sum % 11 == (ISBN[12] - 48)) 21 printf("Right "); 22 else 23 { 24 for(int i = 0; i < 12; i ++) 25 printf("%c", ISBN[i]); 26 if(sum % 11 == 10) 27 printf("X "); 28 else 29 printf("%c ", sum % 11 + 48); 30 } 31 }
另外,对于这个题目,CCF不要求一次输入多组数据,但是这里写成输入多组数据
只有这些写法是AC的
①while(gets(ISBN) && ISBN[0] != NULL)
②while(gets(ISBN) && ISBN[0])
③while(scanf("%s", ISBN) != EOF)
按道理应该这么写啊:
④while(gets(ISBN) != NULL)
可是只得80分
最后发现唯一可能出现的问题就是如果输入为回车
①while(gets(ISBN) && ISBN[0] != NULL)//回车和CTRL+Z结束
②while(gets(ISBN) && ISBN[0])//同上
③while(scanf("%s", ISBN) != EOF)//只有CTRL+Z结束,回车是回车
④while(gets(ISBN) != NULL)//只有CTRL+Z结束,回车是“ 0”,输入“ 0”是Right
好乱。。。。没什么意义的问题。。。不想了。测评机本身也没有输入多组数据。。。好浪费时间
唯一就是记住while输入的时候最后memset就好了。
http://c.biancheng.net/view/1796.html
https://m.imooc.com/wenda/detail/338122
scanf的%s遇到空格终止
gets读取一行