CCF ISBN
GerJCS 人气:2题目原文
问题描述(题目链接登陆账号有问题,要从这个链接登陆,然后点击“模拟考试”,进去找本题目)
试题编号: | 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\n"); 19 else if((sum % 11 == (ISBN[12] - 48))) 20 printf("Right\n"); 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\n"); 28 else 29 printf("%c\n", 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\n", ISBN[0]); 10 // printf("%d\n", 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\n"); 22 else 23 { 24 for(int i = 0; i < 12; i ++) 25 printf("%c", ISBN[i]); 26 printf("%c\n", 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\n", ISBN[0]); 10 // printf("%d\n", 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\n"); 22 else 23 { 24 for(int i = 0; i < 12; i ++) 25 printf("%c", ISBN[i]); 26 if(sum % 11 == 10) 27 printf("X\n"); 28 else 29 printf("%c\n", 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\n", ISBN[0]); 12 // printf("%d\n", 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\n"); 24 else if((sum % 11 == (ISBN[12] - 48))) 25 printf("Right\n"); 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\n"); 33 else 34 printf("%c\n", sum % 11 + 48); 35 } 36 } 37 }
学习到另外一个方法,
边输入边处理也挺好的
加载全部内容