Codeup 又一版A+B[100000579]

这篇博客介绍了一个简单的进制相加问题,即Codeup上的题目100000579。由于A和B的值可能达到2^31 - 1,因此需要使用long long类型来存储。作者通过进制相除法来解决这个问题,具体方法是模拟除法过程进行数值转换。在C语言实现中,利用64位整型数组处理可能的最大位数,并从高位开始输出结果。文章提供了相应的C代码示例。
摘要由CSDN通过智能技术生成

这是1个简单的进制相加的问题,其要求如下:
又一版A+B求解思路如下:

  1. 由于A与B的值为 2 31 − 1 2^{31}-1 2311,因此其相加最大值为 2 32 2^{32} 232,因此不能使用int进行存储
  2. 这里使用long long类型进行存储,由于是数值转换,因此可以使用计算机课程学过的进制相除法

该方法使用方式如下,比如有1个10进制数11,要转换成2进制数,则其操作过程如下:

  1. 使用11除以2,商为5,余1
  2. 使用商5除以2,商为2,余1
  3. 使用2除以2,商为1,余0
  4. 使用1除以2,商为0,余1

由于商为0,无法再进行除法,因此进制转换结束,因此10进制数11的2进制数为1101。
而2个整型数相加,其最大长度为32+32=64位,因此初始化1个64位的整型数组。而计算机中值存储是从低位往高位,因此在输出时需要从高位开始输出。

对应的C代码如下:

#include <stdio.h>

int main(){
    int arr[64] = {0};
    long long a,b,total;
    long m;
    while(scanf("%ld",&m)!=EOF){
        if(m==0){
            break;
        }
        scanf("%lld%lld",&a,&b);
        total = a + b;
        int i=0;
        //如果值为0,将跳出循环。如果初始值为0,那么数组将越界访问,即j此时的值为-1
        if(total>0){
            while(total!=0){
                arr[i] = total % m;
                total /= m;
                i++;
            }
            //从高位开始输出
            for(int j=i-1;j>=0;j--){
                printf("%d",arr[j]);
            }
        }else{
            printf("0");
        }
        printf("\n");
    }
    return 0;
}

最终测试结果:
通过结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值