书号验证

2004年起,国际ISBN中心出版了《13位国际标准书号指南》。
原有10位书号前加978作为商品分类标识;校验规则也改变。
校验位的加权算法与10位ISBN的算法不同,具体算法是:
用1分别乘ISBN的前12位中的奇数位(从左边开始数起),用3乘以偶数位,乘积之和以10为模,10与模值的差值再对10取模(即取个位的数字)即可得到校验位的值,其值范围应该为0~9。下面的程序实现了该算法,请仔细阅读源码,填写缺失的部分。// 验证成功返回1,否则返回0
int f(const char* s){
int k=1;
int sum = 0;
int i;
for(i=0; s[i]!=’\0’; i++){
char c = s[i];
if(c==’-’ || c==’ ') continue;
sum += _________________________________________ ; //填空
k++;
if(k>12) break;
}while(s[i]!=’\0’) i++;
return (s[i-1]-‘0’) == (10-sum % 10)%10;
}int main()
{
printf("%d\n",f(“978-7-301-04815-3”));
printf("%d\n",f(“978-7-115-38821-6”));
return 0;
}注意:只提交空缺的代码,不要抄写已经存在的代码。C语言基础的IF-ELSE 的三目表达式,直接根据题意写上就好了

k%2==0?3*(c-‘0’):(c-‘0’)

***解题思路***

1、分析代码查看代码缺失的功能。

2、补充未实现的代码。

3、缺失的实现部分为:用1分别乘ISBN的前12位中的奇数位(从左边开始数起),用3乘以偶数位,乘积之和

答案: k%2==0?3*(c-‘0’):(c-‘0’);
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值