P1055 [NOIP2008 普及组] ISBN 号码
这题折磨了我很久,主要是字符和数字之间的装换我不了解,导致花费了很多是时间,
数字和字符装换之间的算上48 中间差值为48 具体操作时候可以
这题的一个坑为再计算flag的 时候也需要进行 将字符转换为 数字的操作,我就是在 这里卡了很久的时间,因此,下次写题的时候遇到字符和数字转换的时候要考虑清楚职之间的转换逻辑
具体的代码和注释如下所示
#include<iostream>
#include<algorithm>
using namespace std;
char yxc;// 计算出来的标识码
char a[14];//用一个数组来记录所用编码
char y;// 代表 标识码
int main()
{
for(int i=0;i<13;i++) {
cin>>a[i];
}
int flag=(a[0]-48)*1+(a[2]-48)*2+(a[3]-48)*3+(a[4]-48)*4+(a[6]-48)*5+(a[7]-48)*6+(a[8]-48)*7+(a[9]-48)*8+(a[10]-48)*9;//暴力求值,因为是字符所以减去48
flag%=11;
//在进行计算的时候别忘记将其装换为数字
if(flag==10){//计算余数为10的情况
yxc='X';
y=a[12];
}else {
yxc=flag+48;
y=a[12];
}
if(yxc==y){//输出的步骤
cout<<"Right"<<endl;
} else {
if(flag==10) a[12]=yxc;//在这里进行判断 可以省略为一起,当时脑子瓦特了
else a[12]=yxc;
for(int i=0;i<13;i++)
{
cout<<a[i];
}
}
return 0;
}