[NOIP2008]ISBN号码_牛客题霸_牛客网 (nowcoder.com)
#include<stdio.h>
int main()
{
int a,b,c,d,e,f,g,h,i;
char j,k;
scanf("%1d-%1d%1d%1d-%1d%1d%1d%1d%1d-%c",&a,&b,&c,&d,&e,&f,&g,&h,&i,&j);//%1d是只读取1位数字
k=(a*1+b*2+c*3+d*4+e*5+f*6+g*7+h*8+i*9)%11;//此时,k虽然是char定义,但因为是整型运算后的结果仍是整型
k=(k==10?'X':k+'0');//转换k,如果k等于10,则把k变为X,若k不等于10,而是其它整型,那就需要给它加上'0',让它从整型变为数字字符
if(k==j)//k现在是字符,j一直是字符,故直接比较
{
printf("Right");
}
else
{
printf("%1d-%1d%1d%1d-%1d%1d%1d%1d%1d-%c",a,b,c,d,e,f,g,h,i,k);
}
return 0;
}
总结:
整型加'0'变为数字字符
%1d只读取1位