ISBN号码(洛谷-P1055)

题目描述

每一本正式出版的图书都有一个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号码(包括分隔符“-”)。

输入输出样例

输入样例#1: 

0-670-82162-4

输出样例#1: 

Right

输入样例#2: 

0-670-82162-0

输出样例#2: 

0-670-82162-4

源代码

#include<iostream>  
#include<cstring> 
using namespace std;  
int main()  
{  
    char a[14];
    int	total=0;  
    cin >> a;  
     
    for(int i = 0; i < 11; i++)//按规则计算号码
    {  
        if(i == 1 || i == 5)	continue;  
        else if(i == 0)	total+=a[i]-'0'; 
        else if(i > 1 && i < 5)total+=i*(a[i]-'0');
        else	total+=(i-1)*(a[i]-'0'); 
    }  
    total%=11;//除11求余数
    
    if(total== (a[12]-'0'))        cout << "Right" << endl;//满足条件
    else if(total==10)
    {  
        if(a[12]=='X')          cout <<"Right"<< endl;//满足条件
        else//不满足条件,输出正确的结果
        {  
            a[12] = 'X';  
            a[13] = '\0';  
            cout <<a<< endl;  
        }  
    }  
    else//不满足条件,输出正确的结果
    {  
        a[12] =total+'0';  
        a[13] = '\0';  
        cout <<a<< endl;  
    }  
    return 0;  
}  

 

### C语言洛谷P1055解决方案 对于洛谷平台上的题目 P1055ISBN 码》,该问题主要涉及字符串处理以及简单的算术运算。下面提供一种基于C语言的解法。 #### 题目描述简化 给定一本书籍的ISBN码(不包括最后一位校验位),计算并验证其合法性。具体来说,就是通过前九位数按照特定权重相加后的模数来决定第十位应为何值以确保整个序列有效。 #### 实现思路 程序首先读入一串字符作为输入数据;接着遍历这串字符中的每一位数字,并依据位置赋予相应的权值进行累乘求和操作;最终根据所得总和确定预期的检验码并与实际给出的最后一字符对比判断正误。 下面是具体的实现代码: ```c #include <stdio.h> #include <ctype.h> int main() { char isbn[14]; int sum = 0; gets(isbn); for (int i = 0; i < 9; ++i) { if (!isdigit(isbn[i])) continue; sum += ((isbn[i] - '0') * (i + 1)); } int expected_checksum = sum % 11; char actual_checksum = tolower(isbn[9]); if ((expected_checksum == 10 && actual_checksum == 'x') || (actual_checksum >= '0' && actual_checksum <= '9' && expected_checksum == actual_checksum - '0')) { puts("Right"); } else { isbn[9] = (expected_checksum == 10)? 'X': ('0'+expected_checksum); printf("%s\n", isbn); } return 0; } ``` 此段代码实现了对书籍ISBN的有效性检测逻辑[^1]。需要注意的是,在真实环境中应当更加严谨地对待输入输出流的安全性和健壮性的保障措施,比如使用`fgets()`代替可能存在风险的`gets()`函数等改进方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值