题目描述如下:

知识点①:char数组与int型数字进行运算时,需要将 char[i]-'0' 。比如

    char c[5];
int i;
for(i=0;i<5;i++)
scanf("%c",&c[i]);
printf("%d",c[0]);

当输入c[0] = 5时,以%d形式输出c[0] ,输出结果为 53,所以在进行运算是需要减去48。

注意①:在进行简单的数组运算时,一定要保证下标的计算正确,不要出现低级错误。

我的题解(只有80分):

#include <stdio.h>
int main(){
char ISBN[30];
int i = 0, j = 0, t;
int sub = 0;
for(i = 0; i < 14; i++){
scanf("%c", &ISBN[i]);
}
for(i = 0; i <= 11; i++){
if(i!=1 && i!=5 && i!=11){
j+=1;
sub = sub + j * (ISBN[i]-'0');
}
}
t = sub%11;
if(t == (ISBN[12]-'0')){
printf("Right");
return 0;
}
if(t == 10){
ISBN[12] = 'X';
for(i = 0; i <= 12; i++)
printf("%c", ISBN[i]);
return 0;
}
ISBN[12] = t+'0';
for(i = 0; i <= 12; i++)
printf("%c", ISBN[i]);
return 0;
}

优质题解:

#include <stdio.h>//代码简洁明了(个人观点)
int main(void){
char a[14], mod[12] = "0123456789X"; //先将mod11后的十一个字符存入数组
gets(a); //输入字符串
int i, j = 1, t = 0;
for(i = 0; i < 12; i++) {
if(a[i] == '-') continue; //字符串为分隔符‘-’时跳过此次循环进入下一次循环
t += (a[i]-'0')*j++; //t储存 第j个 数字 * j 的和
}
if(mod[t%11] == a[12]) printf("Right");
else {
a[12] = mod[t%11]; //若识别码错误,则赋正确的识别码,然后输出
puts(a);
}
return 0;
}

------来源于洛谷作者:小k

定义了一个mod数组,一共有11个值,"0123456789X" ,

a[12] = mod[t%11]; //若识别码错误,则赋正确的识别码,然后输出

最新文章

  1. [LeetCode] Peeking Iterator 顶端迭代器
  2. 不用css3的响应式img(按比例缩小图片)
  3. 穿越之旅之--android中如何执行java命令
  4. linux
  5. Nexus3.0.0+Maven的使用(一)
  6. a标签中调用js方法
  7. 【Eclipse】修改 编码格式
  8. 【翻译】Kinect v2程序设计(C++) BodyIndex篇
  9. LeetCode Longest Substring with At Most Two Distinct Characters
  10. Android --ListView模板
  11. Codevs 3287 货车运输 2013年NOIP全国联赛提高组(带权LCA+并查集+最大生成树)
  12. matlab操作之--读取指定文件夹下的“指定格式”文件
  13. 利用DreamweaverCS5制作一个含有动态标题的教程
  14. HDU 4464 Browsing History(最大ASCII的和)
  15. Redis常用数据类型和事物以及并发
  16. vue组件里定时器销毁问题
  17. Python全栈学习_day002知识点
  18. python3.7安装
  19. linux 查看端口占用
  20. 禁止表单操作及JS控制输入的方式

热门文章

  1. Kubernetes常见的部署方案(十四)
  2. R-B Tree
  3. synchronized、ReentrantLock、volatile
  4. JSP中获取各种路径的方法
  5. 控制器view生命周期
  6. xss标签和属性爆破
  7. YOLOv5模型训练及检测
  8. KC705E增强版基于FMC接口的 Kintex-7 XC7K325T PCIeX8 接口卡
  9. Solution -「CF 623E」Transforming Sequence
  10. 【流行前沿】联邦学习 Partial Model Averaging in Federated Learning: Performance Guarantees and Benefits