【p081】ISBN号码
生活随笔
收集整理的這篇文章主要介紹了
【p081】ISBN号码
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
Time Limit: 1 second
Memory Limit: 50 MB
【問題描述】
????每一本正式出版的圖書都有一個(gè)ISBN號(hào)碼與之對(duì)應(yīng),ISBN碼包括9位數(shù)字、1位識(shí)別碼和3位分隔符,其規(guī)定格式如“x-xxx-xxxxx-x”,其中符號(hào)“-”是分隔符(鍵盤上的減號(hào)),最后一位是識(shí)別碼,例如0-670-82162-4就是一個(gè)標(biāo)準(zhǔn)的ISBN碼。ISBN碼的首位數(shù)字表示書籍的出版語言,例如0代表英語;第一個(gè)分隔符“-”之后的三位數(shù)字代表出版社,例如670代表維京出版社;第二個(gè)分隔符之后的五位數(shù)字代表該書在該出版社的編號(hào);最后一位為識(shí)別碼。????識(shí)別碼的計(jì)算方法如下:
????首位數(shù)字乘以1加上次位數(shù)字乘以2……以此類推,用所的結(jié)果mod11,所得的余數(shù)即為識(shí)別碼,如果余數(shù)為10,則識(shí)別碼為大寫字母X。例如ISBN號(hào)碼0-670-82162-4中的識(shí)別碼4是這樣得到的:對(duì)067082162這9個(gè)數(shù)字,從左到右,分別乘以1,2,…9,再求和,即0×1+6×2+……+2×9=158,然后取158 mod 11的結(jié)果4作為識(shí)別碼。
????你的任務(wù)是編寫程序判斷輸入的ISBN號(hào)碼中識(shí)別碼是否正確,如果正確,則僅輸出“Right”;如果錯(cuò)誤,則輸出你認(rèn)為是正確的ISBN號(hào)碼。
【輸入格式】
????只有一行,是一個(gè)字符序列,表示一本書的ISBN號(hào)碼(保證輸入符合ISBN號(hào)碼的格式要求)。
【輸出格式】
????共1行,假如輸入的ISBN號(hào)碼的識(shí)別碼正確,那么輸出“Right”;否則,按照規(guī)定的格式,輸出正確的ISBN號(hào)碼(包括分隔符“-”)。
【輸入樣例1】
????0-670-82162-4【輸出樣例1】
????Right【輸入樣例2】
????0-670-82162-0【輸出樣例2】
????0-670-82162-4 【題解】 把數(shù)字取出來放在1..9.然后對(duì)于識(shí)別碼特判,如果是X則a[10]=10否則等于相應(yīng)的數(shù)字。 然后for i= 1 to 9 然后ans+=a[i]*i; ans再取模一下。 看一下是否和a[10]相同。相同輸出Right。否則把原來的字符串最后一位改成相應(yīng)的值。 注意如果是10要改成X!!! 【代碼】 #include <cstdio>char s[22]; int a[22] = { 0 };void input_data() {scanf("%s", s); //輸入這個(gè)字符串for (int i = 1; i <= 12; i++)if (s[i - 1] != '-') //如果不是減號(hào)則存入a數(shù)組中a[++a[0]] = s[i - 1] - '0';if (s[12] == 'X') //判斷一下識(shí)別碼是啥。a[++a[0]] = 10;elsea[++a[0]] = s[12] - '0'; }void get_ans() {int ans = 0;for (int i = 1; i <= 9; i++) //獲取識(shí)別碼ans += a[i] * i;ans %= 11; //取模if (ans == a[10]) //判斷是否正確printf("Right");else{if (ans == 10) //不正確就自己改成正確的。要特判!s[12] = 'X';elses[12] = ans + '0';printf("%s", s);} }int main() {input_data();get_ans();return 0; }轉(zhuǎn)載于:https://www.cnblogs.com/AWCXV/p/7632315.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的【p081】ISBN号码的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【例9.8】合唱队形
- 下一篇: cogs2109 [NOIP2015]