• P1055 书号


    P1055

    题目描述

      每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括99位数字、11位识别码和33位分隔符,其规定格式如x-xxx-xxxxx-x,其中符号-就是分隔符(键盘上的减号),最后一位是识别码。

      例如  0-670-82162-4 就是一个标准的ISBN码。ISBN码的首位数字表示书籍的出版语言,例如00代表英语;

      第一个分隔符-之后的三位数字代表出版社,例如670670代表维京出版社;

      第二个分隔符后的五位数字代表该书在该出版社的编号;最后一位为识别码。

      识别码的计算方法如下:

      首位数字乘以11加上次位数字乘以22……以此类推,用所得的结果 mod11,所得的余数即为识别码,如果余数为10,则识别码为大写字母X。

      例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对06708216299个数字,从左至右,分别乘以1,2,...,91,2,...,9再求和,

      即0×1+6×2+……+2×9=1580×1+6×2++2×9=158,然后取158mod11的结果4作为识别码。

      你的任务是编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出Right;如果错误,则输出你认为是正确的ISBN号码。

    输入输出格式

      输入格式:

      一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。

       

      输出格式:

      一行,假如输入的ISBN号码的识别码正确,那么输出Right,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符 -)。

    输入输出样例

      输入:

    0-670-82162-4

      输出:

    Right

      输入:

    0-670-82162-0

      输出:

    0-670-82162-4

    代码如下:

     1 #include <bits/stdc++.h>
     2 using namespace std;
     3 int main(){
     4     char s[14],c;
     5     cin>>s;
     6     int j=0,k=0;
     7     for(int i=0;i<11;i++){
     8         if(s[i]!='-')
     9         j+=(s[i]-'0')*(++k);//-0是为了将字符串变成普通数字
    10     }
    11     if(j%11==10)c='X';
    12     else c=j%11+'0';
    13     if(c==s[12])
    14         cout<<"Right"<<endl;
    15     else{
    16         s[12]=c;
    17         cout<<s;
    18     }
    19     return 0;
    20 }
  • 相关阅读:
    闲来无事,编写一个数据迁移小工具
    Moq基础
    探索逻辑事务 TransactionScope
    IntelliJ IDEA安装及jsp开发环境搭建
    数据结构整理(二) 树
    数据结构整理(一) 线性结构
    梳理delegate相关概念
    02_Android应用界面编程_01_视图(View)组件
    01_Android应用开发环境_05_签名android应用程序
    01_Android应用开发环境_04_Android常用开发工具的用法
  • 原文地址:https://www.cnblogs.com/cruelty_angel/p/10381254.html
Copyright © 2020-2023  润新知