目录
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;
}
***新人博主创作不易,希望多多点赞关注呀~