题解 | #十进制数转二进制数#
十进制数转二进制数
http://www.nowcoder.com/practice/90d2de77e05e497eacc85e6b50272900
本题有多种解法
方法一 :Integer.toBinaryString(num)
使用方法如下:
// 将数字转换成字符串
Integer.toString(num);
// 将数字转换成二进制
Integer.toBinaryString(num);
// 将数字转换成八进制
Integer.toHexString(num);
// 将数字转换成十六进制
Integer.toOctalString(num);
题解:
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int num = scanner.nextInt();
//write your code here......
System.out.println(Integer.toBinaryString(num));
}
}
方法二 :Integer.toString(num, 2)
使用方法如下:
Integer.toString(int num, int tar)
str表示要转成字符串的数字,tar表示要转成的进制
Integer.toString(num,2) //将num转换为2进制
题解:
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int num = scanner.nextInt();
//write your code here......
System.out.println(Integer.toString(num, 2));
}
}
方法三 :手动实现
使用方法如下:
通常十进制转其他进制使用辗转相除法来求解(除到结果为1停止),转换结果为最后的商(1)与过程中余数的倒叙结果。
如:例如302
302/2 = 151 余0
151/2 = 75 余1
75/2 = 37 余1
37/2 = 18 余1
18/2 = 9 余0
9/2 = 4 余1
4/2 = 2 余0
2/2 = 1 余0
故二进制为100101110
题解:
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int num = scanner.nextInt();
//write your code here......
fun(num);
}
public static void fun(int tar) {
int temb = tar / 2;
int temp = tar % 2;
if(temb >= 1){
fun(temb);
}
System.out.print(temp);
}
}
额外补充 :适用于8进制和16进制但不适用于二进制方法
使用方法如下:
// %d表示将整数格式化为10进制整数
System.out.printf("%d", num);
// %o表示将整数格式化为8进制整数
System.out.printf("%o", num);
// %x表示将整数格式化为16进制整数
System.out.printf("%x", num);
// %X表示将整数格式化为16进制整数,并且字母变成大写形式
System.out.printf("%X", num);