C语言-详细讲解-P1055 [NOIP2008 普及组] ISBN 号码

目录

1.题目要求

2.题目解读

1.mod

2.gets函数

3.puts函数

3.代码实现

1.题目要求

2.题目解读

这道题题目比较长,可能需要多读几遍才能读懂,重点在于判断识别码是否符合要求,考察了字符串的输入输出,识别码的计算等,没有思路可能会很头大,把思路理清之后就比较简单了~

下面是对题解中的一些知识点介绍:

1.mod

2.gets函数

3.puts函数

3.代码实现

ps:感谢题解区的大佬提供思路

cpp 复制代码
#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 的和
  }//字符型数字减去0的ASCII码值得到整型数字
  if(mod[t%11] == a[12]) printf("Right");
  else {
      a[12] = mod[t%11]; //若识别码错误,则赋正确的识别码,然后输出
      puts(a);
  }
  return 0;
}

***新人博主创作不易,希望多多点赞关注呀~

相关推荐
豐儀麟阁贵2 分钟前
9.1String类
java·开发语言·算法
佳航张9 分钟前
C语言经典100题---例001---组无重复数字的数
c语言·开发语言
chilavert3189 分钟前
技术演进中的开发沉思-225 Prototype.js 框架
开发语言·javascript·原型模式
大大菜鸟一枚9 分钟前
ARM交叉编译环境配置与Qt依赖库部署指南
开发语言·arm开发·qt
星释16 分钟前
Rust 练习册 108:深入探索过程宏的奥秘
开发语言·后端·rust
CoderYanger18 分钟前
动态规划算法-简单多状态dp问题:11.按摩师
开发语言·算法·leetcode·职场和发展·动态规划·1024程序员节
Aurorar0rua19 分钟前
C Primer Plus Notes 12
c语言·开发语言
CoderYanger30 分钟前
动态规划算法-路径问题:10.地下城游戏
开发语言·算法·leetcode·游戏·职场和发展·动态规划·1024程序员节
liu****31 分钟前
11.字符函数和字符串函数(二)
c语言·开发语言·数据结构·c++·算法
@小白鸽32 分钟前
1.2.1创建型设计模式
开发语言·设计模式