題目原文ios
試題編號: | 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
|
將輸入的字符放入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 }
附錄spa
第一次提交50分,忘記了「X」。.net
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」。code
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分blog
不管怎樣加while就是80內存
只有這兩種寫法是對的ci
while(gets(ISBN) && ISBN[0] != NULL)get
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 }