题解 | #[NOIP2008]ISBN号码#

[NOIP2008]ISBN号码

https://www.nowcoder.com/practice/95712f695f27434b9703394c98b78ee5

#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位

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务