201312-2 ISBN号码

问题描述
 
  每一本正式出版的图书都有一个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
 
————————————————————————————————————————————————————————————————————————————————————————
这道题小模拟即可 ,数字转数字字符,+‘0’  ,数字字符转数字 -‘0’
 1 #include<iostream>
 2 #include<string>
 3 #include<vector>
 4 
 5 using namespace std;
 6 
 7 int main()            //  编译很慢 ??????  
 8 {
 9     string s;
10     cin>>s;
11     string s_out(s);
12     
13     int ans = 0;
14     
15     int j=0;
16     for (int i=0;i<s.length()-1;i++)
17     {
18         if (s[i]=='-')continue;
19         j++;
20         ans += j * (s[i]-'0');
21         
22 //        cout<<"j: "<<j<<"ans_c: "<<ans<<endl; 
23     }
24     
25     if ((ans%11==10 && s[s.length()-1]=='X') || (ans % 11) == s[s.length()-1] -'0' )cout<<"Right";
26     
27     else
28     {
29         int w = ans % 11;
30         if (w==10)s_out[s.length()-1]='X';
31         else s_out[s.length()-1] = w+'0';         //     怎样 数字转字符 ??? 
32         cout<<s_out;
33     }
34     
35 //    char s[1];
36 ////    cin>>s;
37 //    int a = 3;
38 //    s[0] = a + '0';
39 //    cout<<s[0];
40     
41     
42     
43     return 0;
44 }
 
 
 
 
原文地址:https://www.cnblogs.com/wuxiaotianC/p/9503804.html