ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

CCP-CSP认证考试 201312-2 ISBN号码 c/c++题解

2019-09-11 19:44:18  阅读:273  来源: 互联网

标签:ISBN 号码 int 题解 识别码 const include 201312


题目描述

试题编号: 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

题解:

这道题其实很简单,可以使用scanf("%*c")来跳过读取字符,就可以直接得到四个数字,然后按题目的要求做判断即可。
注意:最后一个数字要以字符的形式输入,因为有可能是’X’

代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <climits>
#include <cstring>
#include <string>
#include <algorithm>
#include <vector>
#include <deque>
#include <list>
#include <utility>
#include <set>
#include <map>
#include <stack>
#include <queue>
#include <bitset>
#include <iterator>
using namespace std;

typedef long long ll;
const int inf = 0x3f3f3f3f;
const ll  INF = 0x3f3f3f3f3f3f3f3f;
const double PI = acos(-1.0);
const double E = exp(1.0);
const int MOD = 1e9+7;
const int MAX = 1e5+5;
int a,b,c; char d;
int ta,tb,tc; char td;

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);

    scanf("%d%*c%d%*c%d%*c%c",&a,&b,&c,&d);
    ta = a; tb = b; tc = c; td = d;
    int t = 1;
    int sum = 0;
    sum += a*(t);
    t = 4;
    while(b)
    {
        sum += (t--)*(b%10);
        b /= 10;
    }
    t = 9;
    while(c)
    {
        sum += (t--)*(c%10);
        c /= 10;
    }
    if(sum % 11 != 10)
    {
        if(sum % 11 == d-'0')
        {
            cout << "Right" <<  endl;
        }
        else
        {
            printf("%d-%d-%d-%d\n",ta,tb,tc,sum%11);
        }
    }
    else
    {
        if(d == 'X')
        {
            cout << "Right" << endl;
        }
        else
        {
            printf("%d-%d-%d-%c\n",ta,tb,tc,'X');
        }
    }


    return 0;
}

标签:ISBN,号码,int,题解,识别码,const,include,201312
来源: https://blog.csdn.net/qq_41708792/article/details/100746236

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有