新浪博客

C语言-字符串习题-字符和ASCII码的关系

2017-06-19 19:11阅读:
【习题题目】
ISBN识别码判断
每一本正式出版的图书都有一个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号码。
程序运行结果示例1:
0-123-41562-4↙
Right
程序运行结果示例2:
0-123-41562-7↙
0-123-41562-4
输入格式: 用gets()输入字符串
输入只有一行,是一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN的格式要求)。
输出格式:
输入的ISBN号码的识别码正确,输出信息: 'Right'
输入的ISBN号码的识别码错误,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”),输出格式:'%s'
【分析题目】
读题后发现改题考察字符串数组知识。
解题思路:把每一位数字提取出来并乘以一定值求和,然后mod11分析余数。
【代码分析】
#include

int main()
{
char isbn[13];
int i, k = 0, last, p;
gets(isbn);
for (i = 0, p = 0; i < 11; i ++)
{
if (isbn[i] == '-') continue;
p ++;
k += (isbn[i] - 48) * p; //isbn[i] - 48将输入的内容变为数字
}
last = k % 11;
if (last == 10)
last = 'X';
else
last += 48; //last += 48;将数字变成字符
if (last == isbn[12])
printf('Right');
else
{
isbn[12] = last;
printf('%s', isbn);
}
return 0;
}
【心得】
向字符串输入数字时字符串以相对应的ASCII,并不是直接保存数字。
例如:
#include
int main()
{
char isbn[13];
gets(isbn);
printf('%d',isbn[0]);
return 0;
}
当输入1234时,输出49,因为1的ASCII码为49.
#include
int main()
{
int isbn[2],i;
for(i=0;i<2;i++)
{
scanf('%d',&isbn[i]);
}
printf('%d',isbn[0]);
return 0;
}
当输入1回车 2回车 输出1 整型数组保存的是数字的本身值。

我的更多文章

下载客户端阅读体验更佳

APP专享