Java实现十进制整数到二进制的转换
如果想通过自己的代码来实现二进制转换,可使用此段代码,该代码通过输出的字符来表示二进制形式,另外要注意如果想了解该代码的思路。建议先了解计算机组成原理里的原码,反码和补码。正数的原码=反码=补码;负数的反码=原码除符号位按位取反,补码=反码+1。正数的二进制做起来不难,负数的二进制反码做起来也不难,关键就在于反码加1这个操作是很多朋友的烦恼。好了接下来看代码就懂了。
import java.util.Scanner;
//Int类型求二进制数(含正整数和负整数)
public class BinaryConverter{
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
System.out.print("请输入一个十进制数:");
int x=s.nextInt();
String binary="";
final int m=x;
if(m>0){ //求正整数的二进制
for (int i = 0; i <32; i++) {
int y=x % 2;
binary=y+binary;
x/=2;
}
System.out.println(m+"的二进制形式为:"+binary);
}
else if(m<0){ //求负整数的二进制
if(m==Integer.MIN_VALUE){ //Int类型最小值
System.out.print(m+"的二进制形式为:"+1);
for (int i = 0; i < 31; i++) {
System.out.print(0);
}
}
else{
x=-x;
for (int i = 0; i <32; i++) {
int y=x % 2;
if(i==31){
binary=1+binary;
}else{
binary=y+binary;
}
x/=2;
}
System.out.println(m+"的二进制原码形式为:"+binary);
char[] ch=binary.toCharArray(); //toCharArray()用于把字符串类型转换成字符数组
System.out.print(m+"的二进制形式为:");
//除符号位,其它位按位取反,求反码
for (int i = 1; i < ch.length; i++) {
if(ch[i]=='0'){
ch[i]='1';
}
else if(ch[i]=='1'){
ch[i]='0';
}
}
//这里做反码加1操作=补码
if(ch[31]=='0'){ //最后一位是0,直接加1
ch[31]='1';
}
else{ //最后一位如果是1
ch[31]='0';
for (int i =ch.length-2; i>0; i--) {
//从低位往高位遍历,找到第一个为0的数,把该位加1,再把该位到30位(含30)的数全部取0
if(ch[i]=='0'){
int a=i;
ch[a]='1';
for (int j=ch.length-2; j > a; j--) {
ch[j]='0';
}
break;
}
}
}
for (int i = 0; i < ch.length; i++) {
System.out.print(ch[i]);
}
}
}
else{
System.out.print(m+"的二进制形式为:");
for (int i = 0; i < 32; i++) {
System.out.print(0);
}
}
}
}
这里我再提供一个高效的求二进制方法(通过移位)。方法虽简单,但却要朋友们自己领悟了
import java.util.Scanner
public class BinaryConverter{
public static void main(String[] args){
Scanner s=new Scanner(System.in);
System.out.println("请输入一个整数:");
int a=s.nextInt();
for(int i=0;i<32;i++){
int t=(a & 0x80000000>>>i)>>>(31-i);
System.out.print(t);
}
s.close();
}
}