題目原文
試題編號: | 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 }