校验ISBN-10编码

7-34 校验ISBN-10编码

题目描述

图书使用国际标准书号(International Standard Book Number (ISBN-10))来编码,
是一个 10 位码。前 9 位(0−9之间的数字)分别用于表示语言、出版商和 图书信息。
第 10 位是校验位,可以是0−9之间的数字或者是字母 X (用于表示数字10);
ISBN-10码可以通过下面方法进行验证:
首先,对ISBN-10码的各个位按下面的计算式求和:
1x1+2x2+3x3+4x4⋯+9x9+10x10
将求和的结果对11取余数,
如果余为0,则说明该ISBN-10码是一个有效码,否则,就不是一个有效的ISBN-10码。

功能需求

现输入一批ISBN-10图书编码,请你验证该编码是否是有效的国际标准书号。

输入格式:

输入第一行给出正整数N(≤10)是输入的ISBN-10图书编号的个数。
随后N行,每行给出1个10位的ISBN-10图书编号。

输出格式:

按照输入的顺序每行输出1个有问题的ISBN-10编码。
这里并不检验前9位是否合理,只检查前9位是否全为数字且最后1位校验码计算准确。
如果所有号码都正常,则输出 All passed。

输入样例01:

1
0072880082

输出样例01:

All passed

输入样例02:

2
0072880082
084930149X

输出样例02:

084930149X

输入样例03:

3
013168728X
X615880991
026201A530

输出样例03:

X615880991
026201A530

代码内容

#include<stdio.h>
int main()
{
    int m,i,T,k,n=0;
    scanf("%d\n",&T);
    char x[T][15];
    int y[T];
    for(k=0;k<T;k++)
    {
        int t=0;
        gets(x[k]);
        m=strlen(x[k]);
        for(i=0;i<m-1;i++)
        if(x[k][i]>='0'&&x[k][i]<='9')
        t++;
        if(t!=m-1) y[n]=k,n++;
        if(t==m-1)
        {
            int sum=0,r;
            for(i=0;i<m-1;i++)
            sum+=(x[k][i]-48)*(i+1);
            if(x[k][9]!='X')
            sum+=(x[k][9]-48)*10;
            else sum+=10*10;
            r=sum%11;
            if(r!=0) 
            y[n]=k,n++;
        }
    }
    if(n==0) 
    printf("All passed");
    else
    {
       for(i=0;i<n;i++)
       printf("%s\n",x[y[i]]);
    }
    return 0;
}
  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Pretty Boy Fox

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值