写在最前:欢迎批评,欢迎任意地方的指正,用你们的优秀的java代码砸死我吧!!
问题——————
输入两个非负 10 进制整数 A 和 B (≤2^30−1),输出 A+B 的 D (1<D≤10)进制数。
输入格式:
输入在一行中依次给出 3 个整数 A、B 和 D。
输出格式:
输出 A+B 的 D 进制数。
输入样例:
123 456 8
输出样例:
1103
解题思路:
又到了愉快的JAVA作弊时间,这道题使用java 写的话根本不需要任何思路,只要会一个函数就可以 toString,就是每个类都有的函数,对于那几个基础数据类型的包装类来说,这个方法基本都被重写过,都会有一些特殊的用法,如图
这是Long的几个方法,最简单的就是直接调用tostring,然后后面的应该也可以看懂,除了无参toString以外都是静态方法,前三个就是能直接转换成指定进制的方法,最后两个是无符号,这里肯定不适用,第六个就是现在需要用的,返回第二个参数进制的表示形式,点开看看,有一句重要的话:
这里就指定了他的最大和最小,这个可是比较重要,实践出真知,我们直接在代码中查看一下这个大小
可知,最小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));
}
}