计算校验码(C++实训题)

写在前面:仅为个人代码/总结,未必标准,仅供参考!如有错误,还望指出交流,共同进步!

计算校验码

【问题描述】
传送一个B(B≤16)进制的数值N时,最后加上一个一位(B进制的)校验码,使得N加上校验位后能被B-1整除。比如十进制的数值12310,其校验码就是3,因为十进制数值123310能被9整除。16进制的数7816,其校验码为0,因为16进制的78016是15的倍数。超过十进制后,用字母a表示10,字母b表示11,字母c表示12,字母d表示13,字母e表示14,字母f表示15。
告诉你进制B,以及一个B进制的正整数N,要求你计算正整数N在B进制下的校验码。

【输入形式】
输入第一行正整数t (10 ≤ n ≤ 100),表示有多少组测试数据。
后面有t行,每行两个正整数B,N(2≤ B≤16),中间用一个空格隔开,B是10进制整数,N用B进制形式表示。测试数据保证没有非法的B进制数N(也即N中每一位都是在0到B-1之间,没有前导0)。
40%的测试数据N的位数L 1 ≤ L≤ 10;
30%的测试数据N的位数L 1 ≤ L≤ 102;
20%的测试数据N的位数L 1 ≤ L≤ 103;
10%的测试数据N的位数L 1 ≤ L≤ 104;

【输出形式】
对于每组测试数据,输出一位占一行:正整数N在B进制下的校验码。(如果校验码可以为B-1,也可以为0,输出0)。

【样例输入】
4
10 123
16 78
16 1234321
12 ab

【样例输出】
3
0
e
1

【样例说明】
第一行的4表示有4组测试数据,下面四行,每行一组测试数据。
第一组测试数据 10进制数123 最后添加检验码3,10进制数1233是9(=10-1)的倍数
第二组测试数据 16进制数78 最后添加检验码0,16进制数780是15(=16-1)的倍数
第三组测试数据 16进制数1234321 最后添加检验码e(=14),16进制数1234321e是15(=16-1)的倍数
第四组测试数据 12进制数ab 最后添加检验码1,12进制数ab1是11(12-1)的倍数

【Tips】
B进制的数能被B-1整除,当且仅当各位数字和能被B-1整除。
第一组测试数据 10进制数123 最后添加检验码3,10进制数1233各位数字和是9,是9的倍数
第二组测试数据 16进制数78 最后添加检验码0,16进制数780各位数字和是15,是15的倍数
第三组测试数据 16进制数1234321 最后添加检验码e,16进制数1234321e各位数字和是30,是15的倍数
第四组测试数据 12进制数ab 最后添加检验码1,12进制数ab1各位数字和是22,是11的倍数

【示例代码】

#include <bits/stdc++.h>
using namespace std;
bool Judge(int B,char N[],int n)//判断一个多位B进制数是否整除B-1
{
    int num=0,yu=0;
    for(int i=0;i<n;i++)
    {
        if(N[i]<='9')
        {
            num=N[i]-48;
        }
        else
        {
            num=N[i]-87;
        }
        yu=(num*B+yu)%(B-1);
    }
    if(yu==0)
        return true;
    else
        return false;
}
int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        int B;
        char N[10000];
        cin>>B>>N;
        int len=strlen(N);
        char res='\0';
        for(int i=0;i<B;i++)
        {
            if(i<10) {N[len]=i+48;}
            else {N[len]=i+87;}
            bool b=false;
            b=Judge(B,N,len+1);
            if(b==true)
            {
                if(i<10) {res=i+48;}
                else
                {
                    res=i+87;
                }
                break;
            }
        }
        cout<<res<<endl;
    }
    return 0;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LG.田猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值