图书使用国际标准书号(International Standard Book Number (ISBN-10))来编码,是一个 10 位码。前 9 位(0−9之间的数字)分别用于表示语言、出版商和 图书信息。第 10 位是校验位,可以是0−9之间的数字或者是字母 X (用于表示数字10);
ISBN-10码可以通过下面方法进行验证:
首先,对ISBN-10码的各个位按下面的计算式求和: 1×x
1
+2×x
2
+3×x
3
+4×x
4
⋯+9×x
9
+10×x
10
将求和的结果对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 <iostream>
#include <stdio.h>
#include <malloc.h>
void test() {
int n, c = 0;
scanf("%d", &n);
char** p = (char**)malloc(sizeof(char*) * n);
int* q = (int*)malloc(sizeof(int) * (n+1));
for (int i = 0; i < n; i++)
{
char* input=(char*)malloc(sizeof(char)*10);
int count = 0;
for (int j = 0; j < 10; j++)
{
scanf(" %c", &input[j]);
if (input[j] == 'X')
{
count += (j + 1) * 10;
}
else
{
count += ((j + 1) * ((int)input[j]-48));
}
}
*(p + i) = input;
if ((count % 11) != 0)
{
c++;
*(q + i) = 1;
}
else
{
*(q + i) = 0;
}
}
printf("OutPut:\n");
if (c == 0)
{
printf("All passed\n");
}
else
{
for (int i = 0; i < n; i++)
{
if (q[i])
{
for (int j = 0; j < 10; j++)
{
printf("%c", (*(p + i))[j]);
}
printf("\n");
}
}
}
}
void main()
{
while (true)
{
test();
}
}
计算式求和没看明白啥意思
先根据数量产生数组,然后逐行读入ISBN码,检查每个码是否都有数字,最后一位可以是X组成;另外根据计算式计算出校验码,与最后一位比较即可