java程序在控制台输入一个正整数,要求以二进制的形式输出

 我来答
黑马程序员
2017-06-19 · 改变中国IT教育,我们正在行动
黑马程序员
黑马程序员为大学毕业后,有理想、有梦想,想从事IT行业的年轻人改变自己的命运。黑马程序员成就IT黑马
向TA提问
展开全部
  • 利用Java API直接转换

十进制数如何转换为二进制数,这在java API 中有一个方法,Integer.toBinaryString( ) 括号里面写上你要转换的十进制数,这样可以直接转换。例如:

public static void main(String[] args) {

        十进制转换为二进制
        System.out.println(Integer.toBinaryString(10));

    }
  • 通过求余,求商,并计算值(例如:把二进制的1010 直接输成十进制的1010)实现

  • public static void main(String[] args) {
            // TODO Auto-generated method stub

            int a = 123;//定义一个变量并赋给他一个十进制的值
            int remainder;//定义一个变量用于存储余数
            int sum = 0;//定义一个变量用于存放和
            int k = 1;//定义一个变量控制位数

            while(a != 0){

                remainder = a % 10;//对目标数字求余
                a /= 2;//对目标数字求商
                sum = sum + remainder * k;//求和
                k *= 10;//改变位数

            }
            System.out.println("10进制的123转换为2进制结果为:" + sum );
        }
    但是这种方法存在一个问题:因为int类型是有取值范围的,如果转换的二进制数字超出了范围(例如:10011100110110)这个数字明显超出了int的取值范围,这样我们用int类型的sum进行存储的时候他就会自动转换为一个其他的数字。并且这个方法没有办法求负数的二进制数。
  • 在方法二的基础上使用字符串对结果集进行存储

  • public static void main(String[] args) {
            int n = -10;
            String result = "";
            boolean minus = false;

            //如果该数字为负数,那么进行该负数+1之后的绝对值的二进制码的对应位取反,然后将它保存在result结果中
            if(n < 0){
                minus = true;
                n = Math.abs(n + 1);
            }

            while(true){
                int remainder = (!minus && n % 2 == 0) || (minus && n % 2 == 1) ? 0 : 1;

                //将余数保存在结果中
                result = remainder + result;
                n /= 2;

                if(n == 0){
                    break;
                }
            }

            //判断是否为负数,如果是负数,那么前面所有位补1
            if(minus){
                n = result.length();
                for(int i = 1; i <= 32 - n; i++){
                    result = 1 + result;
                }
            }

            System.out.println(result);

        }
    用这种方法就能很好解决int类型的越界问题,能解决所有的十进制转换二进制的问题。
品观人生
2018-03-31 · TA获得超过5902个赞
知道小有建树答主
回答量:40
采纳率:0%
帮助的人:5580
展开全部
public static void main(String[] args) {
        int n = -10;
        String result = "";
        boolean minus = false;
 
        //如果该数字为负数,那么进行该负数+1之后的绝对值的二进制码的对应位取反,然后将它保存在result结果中
        if(n < 0){
            minus = true;
            n = Math.abs(n + 1);
        }
 
        while(true){
            int remainder = (!minus && n % 2 == 0) || (minus && n % 2 == 1) ? 0 : 1;
 
            //将余数保存在结果中
            result = remainder + result;
            n /= 2;
 
            if(n == 0){
                break;
            }
        }
 
        //判断是否为负数,如果是负数,那么前面所有位补1
        if(minus){
            n = result.length();
            for(int i = 1; i <= 32 - n; i++){
                result = 1 + result;
            }
        }
 
        System.out.println(result);
 
    }
 public class Test01 {
        public static void main(String[] args) {
                System.out.println(shi_er(15));
                System.out.println(shi_er(123));
        }
    public static String shi_er(int a) {
        String re = "";
        while (a > 0) {
            int t = a % 2;
            re = String.valueOf(t) + re;
            a = a / 2;
        }
        return re;
    }
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
钱苏联方块
2015-04-26 · TA获得超过147个赞
知道小有建树答主
回答量:91
采纳率:0%
帮助的人:88.1万
展开全部
	public class Test01 {
    public static void main(String[] args) {
         System.out.println(shi_er(15));
         System.out.println(shi_er(123));
    }
public static String shi_er(int a) {
String re = "";
while (a > 0) {
int t = a % 2;
re = String.valueOf(t) + re;
a = a / 2;
}
return re;
}
}

二进制是用字符串形式输出的

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式