详解Python中位运算的简单实现

 更新时间:2022年06月28日 08:46:09   作者:玩转测试开发  
位运算就是直接对整数在内存中对应的二进制位进行操作,一般是将数字化为二进制数后进行操作。本文将利用Python语言实现位运算,感兴趣的可以了解一下

简介

程序中的数在计算机内存中都是以二进制的形式存在的,位运算就是直接对整数在内存中对应的二进制位进行操作,一般是将数字化为二进制数后进行操作。

应用场景

在常规操作和位运算的操作中使用位运算,可以提升性能。但是会造成代码难以理解,建议合理利用。

1、统计奇数

2、统计偶数

3、统计不相同数等

4、求相反数

位运算分有6种:

1、按位与:两个位都为1时,结果才为1(统计奇数)即全1为1。

2、按位或:两个位都为0时,结果才为0(统计偶数)即全0为0。

3、按位异或:两个位相同为0,相异为1(常用统计不相同数)即不同为1。

4、按位取反:0变1,1变0,相当于 -x-1

5、左移运算:各二进位全部左移若干位,高位丢弃,低位补0。

6、右移运算:各二进位全部右移若干位,对无符号数,高位补0,有符号数进行补符号位(算术右移),或者补0(逻辑右移)。

案例源码

# -*- coding: utf-8 -*-
# time: 2022/5/22 17:56
# file: bitwise.py
# 公众号: 玩转测试开发

# &:两个位都为1时,结果才为1(统计奇数)即全1为1。
a1 = 10
b1 = 9
"""
10 = 0b1010
9  = 0b1001
8  = 0b1000
"""
print(bin(a1))
print(bin(b1))
print(a1 & b1)  # 8
print(int("0b1000", 2))

# |:两个位都为0时,结果才为0(统计偶数)即全0为0。
a2 = 10
b2 = 9
"""
10 = 0b1010
9  = 0b1001
11 = 0b1011
"""
print(bin(a2))
print(bin(b2))
print(a2 | b2)  # 11
print(int("0b1011", 2))

# ^:两个位相同为0,相异为1(常用统计不相同数)即不同为1。
a3 = 10
b3 = 9
"""
10 = 0b1010
9  = 0b1001
3  = 0b0011
"""
print(bin(a3))
print(bin(b3))
print(a3 ^ b3)  # 11
print(int("0b0011", 2))

# ~:0变1,1变0,相当于 -x-1
a4 = 10
"""
10 = 0b1010
-x-1 = -11
"""
print(bin(a4))
print(~a4)  # -11
print(int("-0b1011", 2))

# 求相反数
print(~a4 + 1)  # -10

# <<:各二进位全部左移若干位,高位丢弃,低位补0,即:x << n = x * (2 ** n)
a5 = 10
"""
10 = 0b1010
x = 10 * 2 ** 3 = 10 * 2 * 2 * 2
"""
b5 = a5 << 3
print(bin(b5))
print(b5)  # 80
print(int("0b1010000", 2))

# >>:各二进位全部右移若干位,对无符号数,高位补0,有符号数进行补符号位(算术右移),或者补0(逻辑右移)。
#     即:x << n = x / (2 ** n)
a6 = 64
"""
64 = 0b1000000
x = 64 / (2 ** 3) = 64 / (2 * 2 * 2)
"""
b6 = a6 >> 3
print(bin(b6))
print(b6)  # 8

# 经典案例:使用 ^ 找出出现一次的数
a7 = 1 ^ 1 ^ 2
a8 = 1 ^ 2 ^ 1
a9 = 2 ^ 1 ^ 1
print(a7)
print(a8)
print(a9)

# 统计原始方法和位运算方法花费的时间
import time

loop = 30000000
start1 = time.time()
odd_list1 = []

for i in range(loop):
    if i & 1 == 1:
        odd_list1.append(i)
end1 = time.time()
print(f"time1:{end1 - start1}")

start2 = time.time()
odd_list2 = []

for i in range(loop):
    if i % 2 == 1:
        odd_list1.append(i)
end2 = time.time()
print(f"time2:{end2 - start2}")

# time1:5.262001037597656
# time2:4.736037492752075

到此这篇关于详解Python中位运算的简单实现的文章就介绍到这了,更多相关Python位运算内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python运行提示缺少模块问题解决方案

    Python运行提示缺少模块问题解决方案

    这篇文章主要介绍了Python运行提示缺少模块问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • 计算机二级python学习教程(2) python语言基本语法元素

    计算机二级python学习教程(2) python语言基本语法元素

    这篇文章主要为大家详细介绍了计算机二级python学习教程的第2篇,Python语言基本语法元素,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • Python 深入了解opencv图像分割算法

    Python 深入了解opencv图像分割算法

    本文主要介绍了Python通过opencv实现图像分割的详细过程与代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11
  • Python可视化绘制图表的教程详解

    Python可视化绘制图表的教程详解

    python 有许多可视化工具,但本文主要为大家介绍一下Matplotlib。Matplotlib是一种2D的绘图库,它可以支持硬拷贝和跨系统的交互,感兴趣的可以了解一下
    2022-10-10
  • python程序封装为win32服务的方法

    python程序封装为win32服务的方法

    这篇文章主要为大家详细介绍了python程序封装为win32服务的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Numpy数据转换成image并保存的实现示例

    Numpy数据转换成image并保存的实现示例

    本文主要介绍了Numpy数据转换成image并保存的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • Python实现基于Excel数据绘制棋盘图

    Python实现基于Excel数据绘制棋盘图

    这篇文章主要为大家介绍了如何根据可视化的需要,利用Python将Excel中的数据用棋盘图的样式来展示,文中的示例代码简洁易懂,需要的可以参考一下
    2023-07-07
  • Python多线程实例教程

    Python多线程实例教程

    这篇文章主要介绍了Python多线程,对比了新旧版本的Python在实现多线程的特点,并采用threading模块的实例来讲述了多线程的技巧,需要的朋友可以参考下
    2014-09-09
  • Python爬虫Requests库的使用详情

    Python爬虫Requests库的使用详情

    这篇文章主要介绍了Python爬虫Requests库的使用详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • 基于web管理OpenVPN服务的安装使用详解

    基于web管理OpenVPN服务的安装使用详解

    这篇文章主要为大家介绍了基于web管理OpenVPN服务的安装使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02

最新评论