CCF ISBN

Posted gerjcs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CCF ISBN相关的知识,希望对你有一定的参考价值。

题目原文

问题描述(题目链接登陆账号有问题,要从这个链接登陆,然后点击“模拟考试”,进去找本题目
 
试题编号: 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不要求一次输入多组数据,但是这里写成输入多组数据反而只得80分

无论怎样加while就是80

只有这两种写法是对的

while(gets(ISBN) && ISBN[0] != NULL)

while(gets(ISBN) && ISBN[0])

按道理应该这么写啊

while(gets(ISBN) != NULL)

 1 #include <iostream>
 2 #include <stdio.h>
 3 #include<cstring>
 4 char ISBN[15];
 5 int main()
 6 {
 7 //    while(gets(ISBN) != EOF){
 8 //    while(gets(ISBN) != NULL){
 9     while(gets(ISBN) && ISBN[0] != NULL){
10             gets(ISBN);
11 //        printf("%d
", ISBN[0]);
12 //        printf("%d
", ISBN[0] - 48);
13         int sum = 0;
14         int flag = 1;
15         for(int i = 0; i < 11; i ++)
16         {
17             if(ISBN[i] == -)
18                 continue;
19             sum += flag * (ISBN[i] - 48);
20             flag ++;
21         }
22         if( (sum % 11 == 10 && ISBN[12] == X))
23             printf("Right
");
24         else if((sum % 11 == (ISBN[12] - 48)))
25             printf("Right
");
26 
27         else
28         {
29             for(int i = 0; i < 12; i ++)
30                 printf("%c", ISBN[i]);
31             if(sum % 11 == 10)
32                 printf("X
");
33             else
34                 printf("%c
", sum % 11 + 48);
35         }
36     }
37 }

 

学习到另外一个方法,

边输入边处理也挺好的

以上是关于CCF ISBN的主要内容,如果未能解决你的问题,请参考以下文章

ccf131202-ISBN号码

CCF CSP 201312-2 ISBN号码

CCF系列之ISBN号码(201312-2)

CCF 201312-2 ISBN号码 (水题)

CCF 201312-2 ISBN号码 Java

CCF_ 201312-2_ISBN号码