Java 位运算(移位、位与、或、异或、非)

目录

        前言

        一、十进制转二进制

        1. 整形转二进制计算方式概述:

        2 . 小数转二进制计算方式概述:

        3. 负数转二进制计算方式概述:   

        4.  二进制转十进制方式:

二、二进制基本运算

三、JAVA位运算

        1.移位

         2.按位与(&)

         3.按位或(|)

        3.按位非(~)

        3.按位异或(^)

        总结


前言

提示:学习java的位运算,了解其计算方式。


提示:以下是本篇文章正文内容,下面案例可供参考

一、十进制转二进制

1. 整形转二进制计算方式概述:

        正整数目标值除以2,商作为下一次的被除数,依次获取到余数,直到商为0,倒序排序即为二进制值。

        例子:计算6的二进制,结果为 0000 0000 0000   0110

                6/2 = 3 ·····0

                3/2 = 1 ·····1

                1/2 = 0 ·····1

         其结果为:十进制5的二进制为 0000 0000 0000   0110

2 . 小数转二进制计算方式概述:

        整数部分按照整形的计算方式计算,小数部分根据"乘2取整,顺序排列"法

        例子:2.2转二进制 结果为:10.0011001100110011

                2 (十进制)---》 10(二进制)

                0.2(十进制)--> 0.0011001100110011

                        0.2 * 2 = 0.4  取 0

                        0.4 * 2 = 0.8  取 0

                        0.8 * 2 =1.6   取  1

                        0.6 * 2 = 1.2  取 1

                        0.2 * 2 = 0.4  取 0

                        0.4 * 2 = 0.8  取 0

                        0.8 * 2 =1.6  取 1

                        0.6 * 2 = 1.2  取 1

                     

3. 负数转二进制计算方式概述:   

          除2取余,逆序排列 ,0和1互换,原码取反码,反码+1,得补码

          例子:计算-6的二进制,结果为 1111 1111 1111 1000

                a  已计算出6的二进制为0000 0000 0000   0110

                b  0和1互换获取反码  1111 1111 1111 1001

                c  反码+1 得到补码   1111 1111 1111 1010

4.  二进制转十进制方式:

        根据各自的转换方式逆推回去即可

二、二进制基本运算

        加法:0+0=0,0+1=1 ,1+0=1, 1+1=10(向高位进位);

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然可以!下面是对Java位运算和枚举法的简要解释: ### 位运算 位运算是对二进制数进行操作的运算符。Java中包含六种位运算符: 1. 与运算(&):将两个二进制数的每一位进行与操作,当且仅当两个数对应的位都为1时,结果的对应位才为1。 2. 或运算(|):将两个二进制数的每一位进行或操作,当两个数对应的位中有至少一个为1时,结果的对应位就为1。 3. 异或运算(^):将两个二进制数的每一位进行异或操作,当且仅当两个数对应的位不相同时,结果的对应位才为1。 4. 取反运算(~):将一个二进制数的每一位取反,即0变为1,1变为0。 5. 左移位运算(<<):将一个二进制数向左移动指定的位数,右侧空位补0。 6. 右移位运算(>>):将一个二进制数向右移动指定的位数,左侧空位补符号位(即如果原二进制数最高位为1,则移动后的空位补1,否则补0)。 位运算Java中的应用场景很多,例如可以使用位运算进行快速的数值计算和状态控制。 ### 枚举法 枚举法是一种常用的算法思想,其基本思路是枚举所有可能的情况,然后从中找出符合条件的解。在Java中,可以使用枚举类型来实现枚举法。 枚举类型是Java中的一种特殊类型,它允许我们将一组有限的常量放入一个枚举类型中。例如,我们可以定义一个表示星期几的枚举类型: ``` enum Day { MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY } ``` 在枚举类型中,每个常量都是一个枚举类型的实例,我们可以使用枚举类型的实例来代表一个特定的值。例如,我们可以使用Day.MONDAY来表示星期一。 使用枚举类型可以让代码更加清晰和可读,同时也方便进行类型安全的编程。在实现枚举法时,我们通常会将枚举类型作为输入参数,然后枚举其中的所有可能情况,找出符合条件的解。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值