A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© lovefmylgs   /  2014-4-30 23:57  /  10589 人查看  /  82 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我也只会整数的了,同问。
回复 使用道具 举报

java的负数二进制如何转换成十进制

本帖最后由 luorenyu 于 2015-6-26 14:05 编辑

第一步:现将负转换成正二进制
第二步:再讲正二进制转化成十进制
例如数字:-6
-6的负二进制数为:
1111-1111  1111-1111  1111-1111  1111-1010
接下来我们先减一个二进制的1
1111-1111  1111-1111  1111-1111  1111-1010
0000-0000  0000-0000  0000-0000  0000-0001
用上面一排的减去下面一排的最后得到
1111-1111  1111-1111  1111-1111  1111-1001
再将这个数字取反(即将0变为1,将1变为0)最后得到了:
0000-0000  0000-0000  0000-0000  0000-0110
最后将二进制的110转换为十进制
得到了1*2(2)+1*2(1)+1*2(0)=6
注:口号内表示2的指数
我也是新手愿与君共勉
回复 使用道具 举报
第一步:现将负转换成正二进制
第二步:再讲正二进制转化成十进制
例如数字:-6
-6的负二进制数为:
1111-1111  1111-1111  1111-1111  1111-1010
接下来我们先减一个二进制的1
1111-1111  1111-1111  1111-1111  1111-1010
0000-0000  0000-0000  0000-0000  0000-0001
用上面一排的减去下面一排的最后得到
1111-1111  1111-1111  1111-1111  1111-1001
再将这个数字取反(即将0变为1,将1变为0)最后得到了:
0000-0000  0000-0000  0000-0000  0000-0110
最后将二进制的110转换为十进制
得到了1*2(2)+1*2(1)+1*2(0)=6
注:口号内表示2的指数
我也是新手愿与君共勉
回复 使用道具 举报
顶一个!!!
回复 使用道具 举报
class ArrayTest7
{
        public static void main(String[] args)
        {
                toBin(-6);
                System.out.println();
                toOc(8);
                System.out.println();
                toHex(60);
        }
        /*
        十进制-->二进制
        */
        public static void toBin(int num)
        {
                trans(num,1,1);
        }

        /*
        十进制-->八进制
        */
        public static void toOc(int num)
        {
                trans(num,7,3);
        }

        /*
        十进制-->十六进制
        */
        public static void toHex(int num)
        {
                trans(num,15,4);
        }

        public static void trans(int num,int base,int offset)
        {
                if(num==0)
                {
                        System.out.print(0);
                        return;
                }
                char[] chs = {  '0','1','2','3',
                                                '4','5','6','7',
                                                '8','9','A','B',
                                                'C','D','E','F',};
                char[] arr = new char[32];

                int pos = arr.length;

                while(num!=0)
                {
                        int temp = num & base;
                        arr[--pos] = chs[temp];
                        num = num >>> offset;
                }

                for(int x=pos; x<arr.length; x++)
                {
                        System.out.print(arr[x]);
                }
        }
}

回复 使用道具 举报
class ArrayTest7
{
        public static void main(String[] args)
        {
                toBin(-6);
                System.out.println();
                toOc(8);
                System.out.println();
                toHex(60);
        }
        /*
        十进制-->二进制
        */
        public static void toBin(int num)
        {
                trans(num,1,1);
        }

        /*
        十进制-->八进制
        */
        public static void toOc(int num)
        {
                trans(num,7,3);
        }

        /*
        十进制-->十六进制
        */
        public static void toHex(int num)
        {
                trans(num,15,4);
        }

        public static void trans(int num,int base,int offset)
        {
                if(num==0)
                {
                        System.out.print(0);
                        return;
                }
                char[] chs = {  '0','1','2','3',
                                                '4','5','6','7',
                                                '8','9','A','B',
                                                'C','D','E','F',};
                char[] arr = new char[32];

                int pos = arr.length;

                while(num!=0)
                {
                        int temp = num & base;
                        arr[--pos] = chs[temp];
                        num = num >>> offset;
                }

                for(int x=pos; x<arr.length; x++)
                {
                        System.out.print(arr[x]);
                }
        }
}


回复 使用道具 举报
减一取反,再转换成10进制
回复 使用道具 举报
....................
回复 使用道具 举报
负数二进制就是整数二进制取反再加一。
回复 使用道具 举报
    0000-0000 0000-0000 0000-0000 0000-0110     6的二进制
    1111-1111 1111-1111 1111-1111 1111-1001     取反
+  0000-0000 0000-0000 0000-0000 0000-0001
-------------------------------------------------------

回复 使用道具 举报
结果就是1111-1111 1111-1111 1111-1111 1111-1010


回复 使用道具 举报
减一,再取反
回复 使用道具 举报
thinkervsruler 发表于 2014-5-3 01:00
基础测试过了,现在第三步自学阶段

那技术分怎么来的啊?求指导一下,好赞点技术分
回复 使用道具 举报
取反加一,一切ok
回复 使用道具 举报
减一取反
回复 使用道具 举报
希望能帮到你,在二进制中,正数变负数,负数变正数  反码 +1;转换成正数,转换成十进制,再加上负号就行了。


来黑马,这些问题都是so easy
回复 使用道具 举报
负数二进制位减1再取反,形成正数的二进制数,再求得对应的十进制数,最后添加负号即可
回复 使用道具 举报
先说一下 十进制的负数怎么转成二进制 ,比如 -6 如果转成二进制
首先,求出6的二进制数,用一个8位表示就是 00000110
然后,对00000110取反就是:11111001
最后,用11111001做加1操作,得到11111010,这就是-6的二进制表示形式。
这样,把11111010转成十进制就简单啦 , 其实就是倒过来嘛
先用11111010做减1的操作,得到11111001,然后对11111001做取反就是00000110,最后为方便起见,取右边的有效部分110,转成十进制就是1*2^2+1*2^1+0*2^0 = 4 + 2 + 0 = 6,因为是负的二进制,那么结果是-6。
希望可以帮到你!
回复 使用道具 举报
Arron 中级黑马 2015-9-23 22:18:10
39#
把负数的图画出来   接着-1  再取反   得到整数 再算出整数,前面加负号.
回复 使用道具 举报
负数转化整数减一取反,整数转化负数加一取反
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马