题目在此
注意
- 输入格式为 x-xxx-xxxxx-x,需要将"-"过滤掉,用if就行了
- 重新输出ISBN号码时,要重新把"-"添加上
本题目分为三个部分
part 1:定义&输入
定义字符数组,方便删除"-",还有正确识别码,还有k在循环中逐渐增加,做到第一位×0,第二位×1等。和一个h,累加和,j取余,c为正确识别码。
part 2:判断正确识别码
k登场了!如果s[i]项不等于-,k就可以自己+1!,同时使用h累加k×(当前数字转化为int类型的结果),然后直接mod 11赋值给j,接下来.....
1 j=10,c就"X"(注意大小写)
2 j=1-9, c=j转化为int的结果
part 3:判断
如果给出的识别码错误,重新输出ISBN号码,只需将最后一位改为c。若识别码正确(==c)那么就输出"Right"
代码
### 给出代码!(禁止抄袭,可以借鉴)
```cpp
#include<bits/stdc++.h>
using namespace std;
int main()
{
char s[14],c,j;
cin>>s;
int h=0,k=0;
for(int i=0;i<11;i++)
{
if(s[i]!='-')
{
k++;
h+=k*(s[i]-'0');
}
}
j=h%11;
if(j==10)c='X';
else c=j+'0';
if(c==s[12])
{
cout<<"Right"<<endl;
}else{
s[12]=c;
cout<<s;
}
return 0;
}
```