# &: 都是1,才为1,否则为零
# |: 都是0,才为0,否则为1
# ^: 相同为0,相异为1

a = bin(20)
b = bin(16)
print(a)  # 0b10100
print(b)  # 0b10000

# 都为1,才为1
# 因此结果是0b10000
print(20 & 16)  # 16

# 0b10100
print(20 | 16)  # 20

# 0b00100
print(20 ^ 16)  # 4

# >> n 表示右移n位,相当于除以2**n
print(100 >> 2)  # 25
print(100 / (2**2))  # 25.0

# << n 表示左移n位,相当于乘以2**n
print(20 << 2)  # 80
print(20 * (2**2))  # 80

# 如果一个字节中的后四位的值,比如01001101
# 那么只需让01001101对应的值和00001111的值(这里是15)做一个与运算,计算哪几位,哪几位就为1,其余的补0
# 我要是计算后7位呢,那么显然和01111111做一个与运算,显然这里是127

# 要是计算某一位的值,比方说第1位,那么计算的时候右移7位就行了。此时第1位处于最后一位。

# 关于左移和右移
# 11111111,右移,那么移出的部分不要,高位补0,00001111
# 11111111,左移,低位补0,高位保留,111111110000

  

补充:

# 假设用两个字节表示数字
# 1用二进制表示0000 0000 0000 0001
# -1用二进制表示1000 0000 0000 0001
# 那帮计算机科学家们秉承着能少用内存就少用的精神,让最高位表示符号位。0为正,1为负
# 1 = 0000 0000 0000 0001
# -1= 1000 0000 0000 0001
# 将两者相加 1 + -1 = 1000 0000 0000 0010,结果变成-2了。
# 这是为什么?
# 因为在计算机中,数字相加,其实是将补码进行相加,什么叫补码
# 正数--->原码=反码=补码
# 负数--->反码=原码的符号位不变,其他位取反
        # 补码=反码 + 1

# 再来计算一下
# 原码:1000 0000 0000 0001
# 反码:1111 1111 1111 1110 ,符号位不变,其他的位取反,0变1,1变0
# 补码:1111 1111 1111 1111 , 反码 + 1

# 正数的原码等于反码等于补码
# 因此将补码进行相加 1 + -1 = 0000 0000 0000 0000,逢二进一,前面多出去的一位不用管了,不在范围内

# 关于取反操作
print(~9)  # -10
# 这里的结果为什么是-10,难道不应该是-9吗?
# 首先 9 --> 0000 1001,原码反码补码都是它
# 如果取反,表示对补码取反,因为在运算的过程中,都是对补码进行运算
# 0000 1001 取反之后 1111 0110得到取反之后的补码
# 刚说过,运算的时候使用补码,但是在展示给程序猿来看的时候用的还是原码,所以还要将补码转换成原码
# 所以符号位不变其他位取反,得到了反码,1000 1001
# 最后别忘了+1,--> 1000 1010,结果是-10

  

python的位运算的更多相关文章

  1. Python这些位运算的妙用,绝对让你大开眼界

    位运算的性能大家想必是清楚的,效率绝对高.相信爱好源码的同学,在学习阅读源码的过程中会发现不少源码使用了位运算.但是为啥在实际编程过程中应用少呢?想必最大的原因,是较为难懂.不过,在面试的过程中,在手 ...

  2. python 对位运算

  3. 剑指offer用位运算实现两个数相加,及python相关的位操作

    题目:写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. 代码: # -*- coding:utf-8 -*-class Solution:    def Add(self ...

  4. 利用位运算进行a+b的计算(Java&&Python)

    题目链接 需要用到的位运算操作:异或(^).与(&).右移(<<) 异或运算:又称不进位加法,a^b得到的结果为a与b相加,但是需要进位的地方不进位得到的结果 与运算:找出来a和b ...

  5. python位运算

    什么是位运算 位运算就是把数字当成二进制来进行计算,位运算有六种:&(与), |(或), ^(异或), ~(非), <<(左移), >>(右移) &(与) &a ...

  6. Python语言中的按位运算

    (转)位操作是程序设计中对位模式或二进制数的一元和二元操作. 在许多古老的微处理器上, 位运算比加减运算略快, 通常位运算比乘除法运算要快很多. 在现代架构中, 情况并非如此:位运算的运算速度通常与加 ...

  7. Python 进制转换、位运算

    一.进制转换 编程用十进制,十进制转换为二进制.八进制.十六进制 In [135]: bin(23) Out[135]: '0b10111' In [136]: oct(23) Out[136]: ' ...

  8. jave 逻辑运算 vs 位运算 + Python 逻辑运算 vs 位运算

    JAVA中&&和&.||和|(短路与和逻辑与.短路或和逻辑或)的区别 博客分类: 面试题目 Java.netBlog  转自 :http://blog.csdn.net/web ...

  9. Python笔记_第一篇_面向过程_第一部分_3.进制、位运算、编码

    通过对内存这一个部分的讲解,对编程会有一个相对深入的认识.数据结构是整个内存的一个重要内容,那么关于数据结构这方面的问题还需要对进制.位运算.编码这三个方面再进行阐述一下.前面说将的数据结构是从逻辑上 ...

随机推荐

  1. Mysql处理海量数据时的一些优化查询速度方法【转】

    最近一段时间由于工作需要,开始关注针对Mysql数据库的select查询语句的相关优化方法.由于在参与的实际项目中发现当mysql表的数据量达到百万级时,普通SQL查询效率呈直线下降,而且如果wher ...

  2. Javascript Step by Step - 01

    基本数据类型 简单数值类型: undefined, null, boolean, number和string,共有5种 复合数据类型:object,array,function typeof操作符用来 ...

  3. BZOJ [Poi2012]Fibonacci Representation

    找最近的数 记忆化 (我也不知道为什么对的) #include<cstdio> #include<algorithm> #include<map> using na ...

  4. Jenkins拾遗--第三篇(用户权限管理)

    采访过很多实用Jenkins的同学,发现Jenkins的安全是一个很薄弱的地方.很多公司用作生产部署的Jenkins安全管理都不是很规范,就更别提测试用的Jenkins了. 其实Jenkins是一个很 ...

  5. CodeIgniter学习笔记四:CI中的URL相关函数,路由,伪静态,去掉index.php

    一.URL相关函数 1.加载url模块 加载url有两种方式: a.自动加载:在 application/config/autoload.php 中开启 $autoload['helper'] = a ...

  6. 【Luogu P2257】YY 的 GCD

    题目 求: \[ \sum_{i = 1}^n \sum_{j = 1}^m [\gcd(i, j) \in \mathbb P] \] 有 \(T\) 组数据, \(T\le 10^4, n, m\ ...

  7. 每天一个Linux命令(10):mv命令

    mv命令用来对文件或目录重新命名,或者将文件从一个目录移到另一个目录中.source表示源文件或目录,target表示目标文件或目录.如果将一个文件移到一个已经存在的目标文件中,则目标文件的内容将被覆 ...

  8. 板载raid 安装Ubuntu 黑屏

    最近有碰到过产线反馈supermicro x10主板板载raid安装ubuntu桌面版 ,出现安装完成后黑屏,现象是能正常识别faker raid 但是第一次重启,就会出现黑屏,只有左上角广光标在闪, ...

  9. hnust 罚时计算器

    问题 F: 罚时计算器 时间限制: 1 Sec  内存限制: 128 MB提交: 229  解决: 63[提交][状态][讨论版] 题目描述 一般 ACM程序设计比赛都是五个小时.但是比赛结束时,DB ...

  10. Linux大小端模式转换函数

    转自 http://www.cnblogs.com/kungfupanda/archive/2013/04/24/3040785.html 不同机器内部对变量的字节存储顺序不同,有的采用大端模式(bi ...