当前位置: 首页 > news >正文

【python】Python中位运算算法详细解析与应用实战

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,PyQt5和Tkinter桌面开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,云原生K8S,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:python综合应用,基础语法到高阶实战教学
景天的主页:景天科技苑

在这里插入图片描述

文章目录

  • Python中位运算的详细用法教程
    • 一、位运算符简介
      • 1.1 按位与(&)
      • 1.2 按位或(|)
      • 1.3 按位异或(^)
      • 1.4 取反(~)
      • 1.5 左移位(<<)
      • 1.6 右移位(>>)
    • 二、位运算的实际应用案例
      • 2.1 快速判断奇偶性
      • 2.2 交换两个数的值(不使用临时变量)
      • 2.3 权限设置
      • 2.4 图像处理
      • 2.5 位掩码(Bitmask)
      • 2.6 高效遍历
      • 2.7 加密和哈希
    • 三、总结

Python中位运算的详细用法教程

在Python中,位运算是一种对二进制数进行操作的运算方式,它们直接对二进制位进行操作,而不考虑这些位所表示的实际值。位运算因其高效性、节省空间以及逻辑清晰的特点,在网络编程、密码学、图形处理等领域有着广泛的应用。本文将详细介绍Python中的位运算符,包括按位与(&)、按位或(|)、按位异或(^)、取反(~)、左移位(<<)、右移位(>>)和无符号右移位(>>>,但注意Python中没有无符号右移运算符),并通过实际案例来展示它们的用法。

一、位运算符简介

1.1 按位与(&)

按位与运算符(&)用于将两个数的每个二进制位进行比较,如果两个相应位都为1,则该位为1;否则为0。这个运算符常用于提取指定位的信息、清零特定位等操作。

示例
假设我们有两个二进制数0b10110b1100,我们可以使用按位与运算符来提取它们的共同位。

result = 0b1011 & 0b1100
print(bin(result))  # 输出: 0b1000

1.2 按位或(|)

按位或运算符(|)用于将两个数的每个二进制位进行比较,如果两个相应位中有一个为1,则该位为1;否则为0。这个运算符常用于设置特定位为1、将多个条件合并等。

示例
同样以0b10110b1100为例,使用按位或运算符来将它们的对应位中的任何一个为1的位设置为1。

result = 0b1011 | 0b1100
print(bin(result))  # 输出: 0b1111

1.3 按位异或(^)

按位异或运算符(^)用于将两个数的每个二进制位进行比较,如果两个相应位不同,则该位为1;否则为0。这个运算符常用于二进制数据的加密、检查两个数是否相同等。

示例
0b10110b1100为例,使用按位异或运算符来检查它们的对应位是否相同。

result = 0b1011 ^ 0b1100
print(bin(result))  # 输出: 0b0111

1.4 取反(~)

取反运算符(~)用于将一个数的每个二进制位取反,即0变成1,1变成0。但需要注意的是,在Python中,对于有符号整数,取反操作实际上是对其补码进行取反,因此结果可能不是直观的。

示例
假设我们有一个二进制数0b1010,我们可以使用取反运算符来对其进行取反操作。

num = 0b1010
result = ~num
print(bin(result))  # 输出可能不是直观的结果,因为Python使用补码表示负数
# 正确的理解应该是,先转换为补码,然后取反,得到的是该数的补码的相反数的补码

1.5 左移位(<<)

左移位运算符(<<)将数字的位向左移动指定的位数,高位丢弃,低位补0。这相当于乘以2的n次方。

示例
将二进制数0b1010向左移动两位。

num = 0b1010
result = num << 2
print(bin(result))  # 输出: 0b101000

1.6 右移位(>>)

右移位运算符(>>)将数字的位向右移动指定的位数,低位丢弃,高位补0(对于正数)或者保持符号位不变(对于负数)。这相当于除以2的n次方。

示例
将二进制数0b1010向右移动一位。

num = 0b1010
result = num >> 1
print(bin(result))  # 输出: 0b0101

二、位运算的实际应用案例

2.1 快速判断奇偶性

位运算可以用来快速判断一个整数是奇数还是偶数。由于任何整数的二进制表示中,最低位(即最右边的位)为1时表示该数为奇数,为0时表示该数为偶数,因此我们可以使用按位与运算符(&)与数字1进行运算来判断。

示例

def is_odd(num):return num & 1 == 1def is_even(num):return num & 1 == 0# 测试
print(is_odd(5))  # 输出: True
print(is_even(4)) # 输出: True

2.2 交换两个数的值(不使用临时变量)

使用异或运算符(^)可以在不使用临时变量的情况下交换两个数的值。这种方法利用了异或运算的性质:任何数和0异或都等于它本身,任何数和其自身异或都等于0,且异或运算满足交换律和结合律。

示例

def swap_numbers(a, b):a = a ^ bb = a ^ b  # 此时b变为了原来的aa = a ^ b  # 此时a变为了原来的breturn a, b# 测试
x, y = 5, 10
x, y = swap_numbers(x, y)
print(x, y)  # 输出: 10 5

2.3 权限设置

在位运算中,一个常见的应用场景是权限管理。例如,在操作系统或应用程序中,可以使用位来表示不同的权限,并通过位运算来设置、检查或清除这些权限。

假设我们有以下权限定义:

  • 权限1(0b0001)
  • 权限2(0b0010)
  • 权限3(0b0100)
  • 权限4(0b1000)

示例

# 权限定义
PERMISSION_1 = 0b0001
PERMISSION_2 = 0b0010
PERMISSION_3 = 0b0100
PERMISSION_4 = 0b1000# 用户权限
user_permissions = 0b0110  # 用户具有权限2和权限3# 检查权限
def has_permission(permissions, permission):return (permissions & permission) == permission# 设置权限
def set_permission(permissions, permission):return permissions | permission# 清除权限
def clear_permission(permissions, permission):return permissions & (~permission)# 测试
print(has_permission(user_permissions, PERMISSION_1))  # 输出: False
print(has_permission(user_permissions, PERMISSION_2))  # 输出: Truenew_permissions = set_permission(user_permissions, PERMISSION_1)
print(bin(new_permissions))  # 输出: 0b0111,现在用户有了权限1new_permissions = clear_permission(new_permissions, PERMISSION_2)
print(bin(new_permissions))  # 输出: 0b0101,现在用户没有了权限2

2.4 图像处理

在图像处理中,位运算可以用来实现各种效果,如图像的合并、分离、翻转等。虽然Python本身不是图像处理的首选语言(通常使用如OpenCV、PIL等库),但位运算的概念在底层图像处理算法中仍然非常重要。

示例(简化版):

假设我们有两个简单的图像(以二进制形式表示),我们可以使用位运算来合并它们。这里为了简化,我们使用两个简单的二进制字符串来表示图像。

# 假设有两个简单的二进制图像
image1 = "00110011"
image2 = "11001100"# 使用按位或合并图像(模拟“或”操作下的图像合并)
merged_image = ""
for i, j in zip(image1, image2):merged_image += bin(int(i, 2) | int(j, 2))[2:].zfill(2)print(merged_image)  # 输出: 11111111# 注意:这里的示例非常简化,实际图像处理中需要考虑更多的因素,如图像尺寸、颜色深度等。

2.5 位掩码(Bitmask)

位掩码是位运算中一个非常有用的概念,它通常用于在单个整数中存储多个布尔值(或状态),每个布尔值占据一个位。通过位掩码,我们可以轻松地设置、检查或清除这些布尔值,而无需使用多个单独的变量。

示例

假设我们有一个表示一周中每天是否开门的位掩码。我们可以这样定义它:

  • 星期一:0b00000001
  • 星期二:0b00000010
  • 星期三:0b00000100
  • 星期四:0b00001000
  • 星期五:0b00010000
  • 星期六:0b00100000
  • 星期日:0b01000000
# 定义位掩码
MONDAY = 0b00000001
TUESDAY = 0b00000010
WEDNESDAY = 0b00000100
THURSDAY = 0b00001000
FRIDAY = 0b00010000
SATURDAY = 0b00100000
SUNDAY = 0b01000000# 假设某商店的开门日
open_days = MONDAY | WEDNESDAY | FRIDAY | SATURDAY# 检查是否开门
def is_open(days, day_mask):return (days & day_mask) == day_mask# 测试
print(is_open(open_days, MONDAY))  # 输出: True
print(is_open(open_days, TUESDAY)) # 输出: False# 设置或清除开门日
def set_open_day(days, day_mask, is_open):if is_open:return days | day_maskelse:return days & (~day_mask)# 示例:增加星期二的开门日
open_days = set_open_day(open_days, TUESDAY, True)
print(bin(open_days))  # 输出中应包含TUESDAY的位# 示例:关闭星期日的开门日
open_days = set_open_day(open_days, SUNDAY, False)
print(bin(open_days))  # 输出中不应包含SUNDAY的位

2.6 高效遍历

在某些特定情况下,位运算可以用来实现更高效的遍历或搜索算法。虽然这不是位运算最常见的应用场景,但在处理大量数据时,位运算可以显著减少内存使用和提高执行速度。

例如,在处理集合或列表时,如果元素数量有限且已知,我们可以使用位向量(bit vector)来存储元素的存在性。每个元素对应一个位,如果该位为1,则表示该元素存在;如果该位为0,则表示该元素不存在。

2.7 加密和哈希

虽然现代加密和哈希算法远比简单的位运算复杂得多,但位运算仍然是它们实现中的一个基础组成部分。例如,在一些简单的加密算法中,可能会使用位运算来混淆或置换数据的位。

哈希函数也经常使用位运算来提高其效率和均匀性。例如,它们可能通过位旋转、位反转或位混合等技术来确保哈希值的良好分布。

三、总结

位运算在Python中是一个强大而灵活的工具,尽管Python的高级特性使得它在许多情况下不是处理位运算的首选语言,但了解并掌握位运算的概念和技巧仍然是非常有价值的。通过本文的详细介绍和实际应用案例,希望读者能够更深入地理解Python中的位运算符,并在需要时能够灵活运用它们来解决问题。无论是在性能敏感的应用程序中优化代码,还是在需要直接操作二进制数据的场景中,位运算都提供了一种强大而直接的方法。

相关文章:

【python】Python中位运算算法详细解析与应用实战

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…...

vba 保存word里面的图片_1分钟批量处理100张图片,有Word在

天下苦Word久矣&#xff01;Word不仅是个码字工具&#xff0c;还是个排版工具&#xff0c;而Word在排版方面经常遇到的问题&#xff0c;恐怕说个三天三夜都说不完&#xff01; 好不容易做完了100页的活动方案&#xff0c;交到处女座上司那里&#xff0c;他告诉我&#xff1a;“…...

Android进阶之路 - 字体加粗,定制化字体粗度

在客户端中不论是PC端&#xff0c;还是移动端主要价值之一就体现在用户交互方面&#xff0c;也就是用户体验了&#xff0c;接下来讲的是很常见的字体加粗问题 UI大找茬 深入浅出字体、字体库TextView文本渐变字体阴影、文字阴影字体加粗 - 定制化字体粗度 在开发中经常会遇到…...

ForkJoin框架的解析

Java 的 Fork/Join 框架是 Java 7 中引入的一种强大并发框架&#xff0c;旨在简化多线程编程&#xff0c;特别是对那些可以被递归地拆分成更小任务的任务。Fork/Join 框架的核心思想是将大任务拆分为多个小任务&#xff0c;并行运行这些小任务&#xff0c;然后将结果合并起来得…...

使用IDEA2019.1.4创建“hello world”java程序

使用IDEA创建“hello world”java程序分为4步&#xff1a; 创建工程->创建模块->创建库->创建类 1.创建工程 修改工程名称及地址 上步骤点击finish后&#xff0c;2019.1.4版本会自动弹出创建模块的窗口 2.创建模块 可以在上述窗口的基础上创建模块&#xff0c;也可…...

学习vue3 五,传送,缓存组件以及过渡和过渡列表

目录 Teleport传送组件 keep-alive缓存组件 transition动画组件 1. 过渡的类名 2. 自定义过渡class名 3. transition的生命周期 4.appear transition-group 1. 过渡列表 2. 列表的移动过渡 3. 状态过渡 Teleport传送组件 Teleport Vue 3.0新特性之一。 Teleport 是一…...

MyBatis快速学习

目录 前言 MyBatis的具体使用 一些小工具&#xff1a;MyBatisX 常见问题&#xff1a; 1.表中字段名和实体属性名不一致 2.按条件查询&#xff08;单条件&#xff09;时的&#xff0c;查询条件怎么编写 3.按条件查询&#xff08;多条件&#xff09; 4.多条件查询时&…...

24.8.3数据结构|双向循环链表、静态链表

双向循环链表 节点类型与双链表的节点类型完全相同双向循环链表的操作也与双链表的操作基本一致。 例题 将自然数一到N按由小到大的顺序沿顺时针方向围成一个圈&#xff0c;然后以一为起点先沿顺时针方向数到第N个数将其划去&#xff0c;再沿逆时针方向数到第K个数将其滑去&a…...

C语言典型例题28

《C程序设计教程&#xff08;第四版&#xff09;——谭浩强》 习题2.5 输入一个华氏温度&#xff0c;要求输出摄氏温度。公式为C5/9(F-32)&#xff0c;要求输出要有文字说明&#xff0c;取两位小数 数学知识&#xff1a; &#xff08;1&#xff09;华氏温度与摄氏温度&#x…...

PHP企业培训考试系统小程序源码

&#x1f680;企业培训考试系统&#xff0c;赋能员工成长新引擎&#x1f4da; &#x1f331; 开篇&#xff1a;解锁企业培训新篇章 在快速变化的商业环境中&#xff0c;员工的能力提升是企业持续发展的关键。&#x1f680; 传统的培训方式已难以满足现代企业的需求&#xff0…...

进程状态(三)----- linux 中具体的进程状态(下)

目录 前言1. T && t 状态2. X 与 Z 状态3. 孤儿进程 前言 继上一篇文章 进程状态&#xff08;二&#xff09;----- linux 中具体的进程状态&#xff08;上&#xff09; 介绍了 linux 系统中具体的 R、S、D 状态&#xff0c;而这篇文章继续介绍 linux 系统中剩下的三种…...

关系型数据库(RDBMS,Relational Database Management System)

关系型数据库&#xff08;RDBMS&#xff0c;Relational Database Management System&#xff09;是一种结构化数据存储系统&#xff0c;它使用表&#xff08;Tables&#xff09;、行&#xff08;Rows&#xff09;和列&#xff08;Columns&#xff09;的结构来组织和管理数据。关…...

使用RK Docker环境编译RK SDK

文章目录 前言Docker介绍实验环境获取RK Docker镜像加载RK Docker镜像使用RK Docker环境编译SDK其它 前言 作为一名嵌入式Linux的学习者&#xff0c;目前编译各种平台&#xff0c;用的都是同一个编译机&#xff08;Ubuntu虚拟机&#xff09;。之前一直在折腾全志&#xff0c;所…...

免费【2024】springboot 付费自习室管理系统的设计与实现

博主介绍&#xff1a;✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围&#xff1a;SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…...

【学习方法】高效学习因素 ② ( 学习动机 | 内在学习动机 | 外在学习动机 | 外在学习动机的调整方向 | 保护学习兴趣 | 高考竞争分析 )

文章目录 一、高效学习的其它因素 - 学习动机1、学习动机2、内在学习动机3、外在学习动机4、外在学习动机的问题所在5、外在学习动机的调整方向6、保护学习兴趣7、高考竞争分析 上一篇博客 【学习方法】高效学习因素 ① ( 开始学习 | 高效学习因素五大因素 | 高效学习公式 - 学…...

【学习笔记】A2X通信的协议(四)- A2X PC5通信(二)

目录 6.1.2.4 A2X PC5单播链接释放程序 6.1.2.4.1 概述 6.1.2.4.2 发起UE启动A2X PC5单播链接释放程序 6.1.2.4.3 目标UE接受的A2X PC5单播链接释放程序 6.1.2.4.4 发起UE完成的A2X PC5单播链接释放程序 6.1.2.4.5 异常情况 6.1.2.4.5.1 发起UE的异常情况 6.1.2.5 A2X …...

注意!!可能这是《网络管理员》旧教程最后一次考试,赶紧学起来

网络管理员是软考初级资格热门科目之一。近日在国家版本数据中心&#xff0c;小编查到网络管理员官方教程已经有2024最新版出来了&#xff0c;现在这一版教程说实话有些内容已经过时了&#xff0c;尤其新版教材也已经出现&#xff0c;小编推测明年大概率依据新版考试大纲出题&a…...

array postgre gsql 剔除

进行某种过滤或比较操作&#xff0c;判断不匹配的&#xff0c;数组 array 中列出的所有字符串 and a.Repunittree not like all (array[‘%0001003549950003%’,‘%000100460041%’,‘%000100460047%’,‘%000105880001%’ ,‘%000100020007%’,‘%000105830009%’,‘%0001058…...

【Matlab】零阶保持法:连续状态空间方程(含噪声,非线性)离散化处理方法

常用的离散化方法&#xff1a;零阶保持器&#xff08;zero-order hold&#xff0c;ZOH&#xff09;、欧拉法&#xff08;Euler&#xff09;、一阶保持器&#xff08;First-order hold&#xff0c;FOH&#xff09;。最常用的是前两种。 0.零阶保持器&#xff08;ZOH&#xff09…...

web自动化6-pytest⑦一些基本情况

命名规则 1)import pytest 测试文件名要以test_ 开头或 _test结尾 2&#xff09;类名需要以Test开头&#xff08;T&#xff09;&#xff0c;不能带有init方法 3&#xff09;函数名以test_开头&#xff08;t&#xff09; 符合规则框架才能找到用例&#xff0c;一条用例代表一条函…...

ffmpeg(四):滤镜命令

FFmpeg 的滤镜命令是用于音视频处理中的强大工具&#xff0c;可以完成剪裁、缩放、加水印、调色、合成、旋转、模糊、叠加字幕等复杂的操作。其核心语法格式一般如下&#xff1a; ffmpeg -i input.mp4 -vf "滤镜参数" output.mp4或者带音频滤镜&#xff1a; ffmpeg…...

WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)

一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解&#xff0c;适合用作学习或写简历项目背景说明。 &#x1f9e0; 一、概念简介&#xff1a;Solidity 合约开发 Solidity 是一种专门为 以太坊&#xff08;Ethereum&#xff09;平台编写智能合约的高级编…...

爬虫基础学习day2

# 爬虫设计领域 工商&#xff1a;企查查、天眼查短视频&#xff1a;抖音、快手、西瓜 ---> 飞瓜电商&#xff1a;京东、淘宝、聚美优品、亚马逊 ---> 分析店铺经营决策标题、排名航空&#xff1a;抓取所有航空公司价格 ---> 去哪儿自媒体&#xff1a;采集自媒体数据进…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...

MySQL:分区的基本使用

目录 一、什么是分区二、有什么作用三、分类四、创建分区五、删除分区 一、什么是分区 MySQL 分区&#xff08;Partitioning&#xff09;是一种将单张表的数据逻辑上拆分成多个物理部分的技术。这些物理部分&#xff08;分区&#xff09;可以独立存储、管理和优化&#xff0c;…...

tauri项目,如何在rust端读取电脑环境变量

如果想在前端通过调用来获取环境变量的值&#xff0c;可以通过标准的依赖&#xff1a; std::env::var(name).ok() 想在前端通过调用来获取&#xff0c;可以写一个command函数&#xff1a; #[tauri::command] pub fn get_env_var(name: String) -> Result<String, Stri…...

springboot 日志类切面,接口成功记录日志,失败不记录

springboot 日志类切面&#xff0c;接口成功记录日志&#xff0c;失败不记录 自定义一个注解方法 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;/***…...

uniapp 实现腾讯云IM群文件上传下载功能

UniApp 集成腾讯云IM实现群文件上传下载功能全攻略 一、功能背景与技术选型 在团队协作场景中&#xff0c;群文件共享是核心需求之一。本文将介绍如何基于腾讯云IMCOS&#xff0c;在uniapp中实现&#xff1a; 群内文件上传/下载文件元数据管理下载进度追踪跨平台文件预览 二…...

保姆级【快数学会Android端“动画“】+ 实现补间动画和逐帧动画!!!

目录 补间动画 1.创建资源文件夹 2.设置文件夹类型 3.创建.xml文件 4.样式设计 5.动画设置 6.动画的实现 内容拓展 7.在原基础上继续添加.xml文件 8.xml代码编写 (1)rotate_anim (2)scale_anim (3)translate_anim 9.MainActivity.java代码汇总 10.效果展示 逐帧…...