PAT乙级——1022(模拟进制转换)

题目:D进制的A+B (20 分)

输入两个非负 10 进制整数 A 和 B (≤230−1),输出 A+B 的 D ( 1< D ≤ 10 ) 进制数。

输入格式:
输入在一行中依次给出 3 个整数 A、B 和 D。

输出格式:
输出 A+B 的 D 进制数。

输入样例:
123 456 8

输出样例:
1103

题目分析及实现

对于将十进制转化为任意进制,有一个比较简单的算法:

将这个数对基数依次取余,将余数倒序输出,在倒序输出余数之前正序输出最后一次的商
具体可以参考进制转换!

import java.util.Scanner;

public class Main {
    public static void main(String []args){
        Scanner in =new Scanner(System.in);
        //int型最长2的32次方,int型够用
        int A =in.nextInt();
        int B =in.nextInt()+A;//以后便直接对B进行操作了
        int D =in.nextInt();
        int temp[]=new int[100];
        int i=0;
        //十进制到任意进制,这个数对基数依次取余,倒序输出,在之前正序输出最后一个商
        while (B/D!=0){
            temp[i]=B%D;
            B=B/D;
            i++;
        }
        System.out.print(B);

        for(int j=i-1;j>=0;j--)
            System.out.print(temp[j]);
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值