Leetcode算法基础篇-位运算

ops/2024/9/24 14:28:39/

简介

学习链接:位运算(第 13 ~ 14 天)

位运算规则

运算符描述规则
|按位或运算符只要对应的两个二进位有一个为 1 1 1 时,结果位就为 1 1 1
&按位与运算符只有对应的两个二进位都为 1 1 1 时,结果位才为 1 1 1
<<左移运算符将二进制数的各个二进位全部左移若干位。<< 右侧数字指定了移动位数,高位丢弃,低位补 0 0 0
>>右移运算符对二进制数的各个二进位全部右移若干位。>> 右侧数字指定了移动位数,低位丢弃,高位补 0 0 0
^按位异或运算符对应的两个二进位相异时,结果位为 1 1 1,二进位相同时则结果位为 0 0 0
~取反运算符对二进制数的每个二进位取反,使数字 1 1 1 变为 0 0 0 0 0 0 变为 1 1 1

位运算应用

功 能位运算示例
从右边开始,把最后一个 1 1 1 改写成 0 0 0x & (x - 1)100101000 -> 100100000
去掉右边起第一个 1 1 1 的左边x & (x ^ (x - 1))x & (-x)100101000 -> 1000
去掉最后一位x >> 1101101 -> 10110
取右数第 k k kx >> (k - 1) & 11101101 -> 1, k = 4
取末尾 3 3 3x & 71101101 -> 101
取末尾 k k kx & 151101101 -> 1101, k = 4
只保留右边连续的 1 1 1(x ^ (x + 1)) >> 1100101111 -> 1111
右数第 k k k 位取反x ^ (1 << (k - 1))101001 -> 101101, k = 3
在最后加一个 0 0 0x << 1101101 -> 1011010
在最后加一个 1 1 1(x << 1) + 1101101 -> 1011011
把右数第 k k k 位变成 0 0 0x & ~(1 << (k - 1))101101 -> 101001, k = 3
把右数第 k k k 位变成 1 1 1x | (1 << (k - 1))101001 -> 101101, k = 3
把右边起第一个 0 0 0 变成 1 1 1x | (x + 1)100101111 -> 100111111
把右边连续的 0 0 0 变成 1 1 1x | (x - 1)11011000 -> 11011111
把右边连续的 1 1 1 变成 0 0 0x & (x + 1)100101111 -> 100100000
把最后一位变成 0 0 0x | 1 - 1101101 -> 101100
把最后一位变成 1 1 1x | 1101100 -> 101101
把末尾 k k k 位变成 1 1 1x | (1 << k - 1)101001 -> 101111, k = 4
最后一位取反x ^ 1101101 -> 101100
末尾 k k k 位取反x ^ (1 << k - 1)101001 -> 100110, k = 4

练习题

leetcode.cn/problems/reverse-bits/description/" rel="nofollow">190. 颠倒二进制位

思路

  • 执行操作即可

代码

class Solution:# @param n, an integer# @return an integerdef reverseBits(self, n):n = bin(n)n = str(n)[2:]if len(n) < 32:n = '0'*(32 - len(n)) + n# print(n)n = n[::-1]return int(n, 2)

leetcode.cn/problems/number-of-1-bits/description/" rel="nofollow">191. 位1的个数

思路

  • 利用 x & (x-1)把最右1变0操作来统计1的数量

代码

class Solution(object):def hammingWeight(self, n):""":type n: int:rtype: int"""cnt = 0while n:n = n & (n - 1)cnt += 1return cnt

leetcode.cn/problems/bitwise-and-of-numbers-range/description/" rel="nofollow">201. 数字范围按位与

思路

  • 参考官方题解,写的很明白
  • 找公共前缀,通过位移计算前缀中1的位置。

代码

class Solution(object):def rangeBitwiseAnd(self, left, right):""":type left: int:type right: int:rtype: int"""shift = 0while left < right:left >>= 1right >>= 1shift += 1return left << shift

http://www.ppmy.cn/ops/115325.html

相关文章

EasyPan笔记

环境搭建 创建一个文件夹MyWorkspace-java&#xff0c;使用idea直接打开 创建一个虚拟机&#xff0c;用于其中的mysql5.7的版本&#xff08;本地机版本8&#xff09;&#xff0c;docker环境配置好了 jdk选择1.8/8 配置maven 使用教学的maven文件进行配置 主路径不需要在bin目…

基于FPGA+GPU异构平台的遥感图像切片解决方案

随着遥感和成像技术的不断进步和普及&#xff0c;获取大量高分辨率的遥感图像已成为可能。这些大规模的遥感图像数据需要进行有效的处理和分析&#xff0c;以提取有用的信息&#xff0c;进行进一步的应用。遥感图像切片技术应运而生&#xff0c;该技术可以将大型遥感图像分割成…

Python3爬虫教程-HTTP基本原理

HTTP基本原理 1&#xff0c;URL组成部分详解2&#xff0c;HTTP和HTTPS3&#xff0c;HTTP请求过程4&#xff0c;请求&#xff08;Request&#xff09;请求方法&#xff08;Request Method&#xff09;请求的网址&#xff08;Request URL&#xff09;请求头&#xff08;Request H…

计算机前沿技术-人工智能算法-大语言模型-最新论文阅读-2024-09-23

计算机前沿技术-人工智能算法-大语言模型-最新论文阅读-2024-09-23 本期&#xff0c;我们对大语言模型在表情推荐, 软件安全和 自动化软件漏洞检测等方面如何应用&#xff0c;提供几篇最新的参考文章。 1 Semantics Preserving Emoji Recommendation with Large Language Mod…

集成运放UA741的原理与应用的探索

我们发现TI公司提供了UA741的内部电路&#xff0c;此电路包括22个晶体管&#xff0c;11个电阻&#xff0c;1个二极管&#xff0c;1个电容。 1UA741设计需求 1.1有短路保护 UA741的短路保护功能‌是指当输出端发生短路时&#xff0c;该器件能够自动保护自身&#xff0c;防止因…

gitlab修改访问端口

目录 1.找到gitlab.rb文件&#xff0c;一般在/etc/gitlab/路径下 2.打开配置文件&#xff0c;加上代码 3.重新配置 4.重启gitlab 1.找到gitlab.rb文件&#xff0c;一般在/etc/gitlab/路径下 2.打开配置文件&#xff0c;加上代码 打开文件 sudo vi gitlab.rb 加上默认端口配…

【Qt | Qstring】Qstring详细介绍(字符串的添加、删除、修改、查询、截断、删除空白字符等)

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; ⏰发布时间⏰&#xff1a; 2024-09-24 …

【小白请绕道】Redis 的 I/O 多路复用技术,它是如何工作的?

Redis 的 I/O 多路复用技术是其高性能的关键之一。在单个线程中&#xff0c;Redis 可以同时处理多个网络连接&#xff0c;这是通过使用 I/O 多路复用技术实现的。这种技术允许 Redis 在单个线程中监听多个套接字&#xff0c;并在套接字准备好执行操作时&#xff08;如读取或写入…