PAT 乙级 1022 D进制的A+B Java解决

写在最前:欢迎批评,欢迎任意地方的指正,用你们的优秀的java代码砸死我吧!!

问题——————

输入两个非负 10 进制整数 A 和 B (≤2​^30​​−1),输出 A+B 的 D (1

输入格式:

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

输出格式:

输出 A+B 的 D 进制数。

输入样例:

123 456 8

输出样例:

1103

解题思路:

又到了愉快的JAVA作弊时间,这道题使用java 写的话根本不需要任何思路,只要会一个函数就可以   toString,就是每个类都有的函数,对于那几个基础数据类型的包装类来说,这个方法基本都被重写过,都会有一些特殊的用法,如图

PAT 乙级 1022 D进制的A+B Java解决_第1张图片

这是Long的几个方法,最简单的就是直接调用tostring,然后后面的应该也可以看懂,除了无参toString以外都是静态方法,前三个就是能直接转换成指定进制的方法,最后两个是无符号,这里肯定不适用,第六个就是现在需要用的,返回第二个参数进制的表示形式,点开看看,有一句重要的话:

这里就指定了他的最大和最小,这个可是比较重要,实践出真知,我们直接在代码中查看一下这个大小PAT 乙级 1022 D进制的A+B Java解决_第2张图片

可知,最小2进制,最大36进制,应该是十个数字加26个字母可以表示的最大进制的意思吧。懂了这个东西,就什么都好说了。

package not.die.in.here;
//满分20
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class _1022_DjinzhiAplusB {

	public static void main(String[] args) throws IOException {
		BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
		String[] buf = bf.readLine().split(" ");
		Long A = new Long(buf[0]);
		Long B = new Long(buf[1]);
		int d = Integer.parseInt(buf[2]);
		//System.out.println("最小:"+Character.MIN_RADIX);
		//System.out.println("最大:"+Character.MAX_RADIX);
		System.out.println(Long.toString(A+B, d));
		
	}

}

提交截图:

PAT 乙级 1022 D进制的A+B Java解决_第3张图片

你可能感兴趣的:(PAT题解)