洛谷试炼场已升级为题单,感觉没之前好玩了,我新手村还没弄完。。。

kkksc03 上海洛谷网络科技有限公司 联合创始人
可以理解一些同学的怀旧情怀,但是这两个真的没法共存,因为试炼场是我6年前写的屎山代码,已经严重影响了后端的效率,如果不删掉则无法完成洛谷4的完全重构。(近期502的现象和这个有关)
如果重构同样的功能,则需要花费大量的时间精力。这不值得,因为我们有其他更重要的事情要做。
至于题单,它比试炼场更灵活,题目质量也更好。(事实上,官方题单的题目主要迁移自试炼场,并进行了一些优化),完成进度也还能算是保留试炼场的印迹。如果全部通过一个题单的题目的话,会有一些变化的哦!
至于省选试炼场,当时题目选择质量更低,而用户精选有很多高质量的题单(比如CYJ的集训队题),还能配上训练指导。实际上,学到省选级别,应该就不需要之前那样试炼场给你整理出需要学习的算法,而是可以借助题单创造更加灵活自主的训练方式。
不过大概比较遗憾的是完成任务仪式感没有了吧。

P1055 ISBN号码

题目描述

每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、1位识别码和3位分隔符,其规定格式如x-xxx-xxxxx-x,其中符号-就是分隔符(键盘上的减号),最后一位是识别码,例如0-670-82162-4就是一个标准的ISBN码。ISBN码的首位数字表示书籍的出版语言,例如0代表英语;第一个分隔符-之后的三位数字代表出版社,例如670代表维京出版社;第二个分隔符后的五位数字代表该书在该出版社的编号;最后一位为识别码。

识别码的计算方法如下:
首位数字乘以1加上次位数字乘以2……以此类推,用所得的结果mod11,所得的余数即为识别码,如果余数为10,则识别码为大写字母X。例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对067082162这9个数字,从左至右,分别乘以1,2,...,9再求和,即0×1+6×2+……+2×9=158,然后取158mod11的结果4作为识别码。
你的任务是编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出Right;如果错误,则输出你认为是正确的ISBN号码。

输入格式

一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。

输出格式

一行,假如输入的ISBN号码的识别码正确,那么输出Right,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符-)。

输入输出样例

输入

0-670-82162-4

输出

Right

输入

0-670-82162-0

输出

0-670-82162-4

说明/提示

2008普及组第一题

#include <stdio.h>
int main()
{
    char a[14];
    int q=0, w=0;
    for (int i = 0; i < 14; i++)
        scanf("%c", &a[i]);
    q = (a[0]-'0') * 1 + (a[2] - '0') * 2 + (a[3] - '0') * 3 + (a[4] - '0') * 4 + (a[6] - '0') * 5 + (a[7] - '0') * 6 + (a[8] - '0') * 7 + (a[9] - '0') * 8 + (a[10] - '0') * 9;
    q = q % 11;
    if (q == 10)
        w = 'X';
    else
        w = q + '0';
    if (w == a[12]) 
        printf("Right");
    else
    {
        a[12] = w;
        for (int i = 0; i < 14; i++)
            printf("%c", a[i]);
    }
    return 0;
}

最后修改:2020 年 03 月 29 日
如果觉得我的文章对你有用,请随意赞赏