Java实现十进制整数到二进制的转换(含负整数)

                                 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();
    }
}

 

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值