算法专题:位运算

目录

常见位运算总结

位运算相关算法题

1. 只出现一次的数字

2. 只出现一次的数字(|||)

3. 两整数之和

4. 只出现一次的数字(||)


常见位运算总结

        在开始刷位运算这个类型的题目前,我想先带着大家学习一下一些常见的基础运算操作,我们后面刷题时对题目的处理都是基于这些基本运算。

1. 基础位运算

        想必大家对位运算符都是非常熟悉的,在这里,我为大家讲讲我对几个按位操作符的理解

        &:有0就是0

        | :有1就是1

        ^ :相同为0,相反为1 (也可以视作为无进位相加)

2. 给一个数n,确定二进制表示中第x位是0还是1

        (n >> x) & 1

3. 将一个数n的二进制表示的第x位修改成1

        n |=(1 << x)

4. 将一个数n的二进制表示的第x位修改成0

        n &= (~(1 << x))(~就是取反)

5. 位图的思想

        位图的本质就是个哈希表,我们先前学习过的哈希表在大部分情况下都是数组形式的

使用一个变量的比特位来记录信息,对哈希表的增删查改,就相当于是对比特位的增删查改,这就意味着,我们前面讲到的几种常见的位运算操作都是非常重要的,能帮助我们更好地操作位图

6. 提取一个数n最右侧的1

        这个描述听起来有些抽象,我为大家举个例子:

        这就是提取最右侧的1

        操作方式:n & -n

        -n是由n按位取反再+1得到的:

        通过这个例子我们发现了:n与-n的关系是,在最右侧的1的左侧,n与-n完全相反;在最右侧的1的右侧,n与-n完全相同。则左侧区域两者&的结果必定为0,右侧区域&的结果不变,于是我们实现了把最右侧1提取出来的操作。

7. 干掉一个数n二进制表示中最右侧的1

        n & (n - 1)

        众所周知,减法是存在借位的,n - 1的本质就是,将最右侧的1右侧的区域全部取反

8. 异或运算的运算律

        现在我们已经学习完了常见的操作,接下来开始刷题吧!大家可以先试着做以下几道题练练手,根据我们的总结可以直接处理:

        191. 位1的个数 - 力扣(LeetCode)

        

        461. 汉明距离 - 力扣(LeetCode)

        接下来我们来另外刷下这几道题。希望大家在看讲解前,先自己动手编写代码,实在没有思路时再去看答案,这样才能实际提高水平~

位运算相关算法题

1. 只出现一次的数字

136. 只出现一次的数字 - 力扣(LeetCode)

题目解析:

        这道题目如果我们没有学习过位运算,可能只能想到创建一个哈希表,通过哈希表来找到只出现一次的元素。但事实上,根据我们在常见位运算总结中的第八点:任何书亦或0的结果为这个数本身、两数相同时为0、异或运算满足结合律,我们可以得出一个结论:在数组中出现了两次的元素可以结合为0,因为只出现了一次的元素只有一个,所以我们对整个数组求亦或和,得到的结果就是只出现一次的元素!

代码:

class Solution {
public:int singleNumber(vector<int>& nums) {int k = 0;for(auto num : nums){k ^= num;}return k;}
};

2. 只出现一次的数字(|||)

260. 只出现一次的数字 III - 力扣(LeetCode)

题目解析:

        本题如果使用哈希表,可以非常轻松的解决,但由于面试中,面试官可能会问我们有没有其他的解法,所以我们这里试着用位运算来处理。本题与上一题的区别在于,仅出现一次的元素有两个,我们就不能简单地求整个数组的亦或和,而是要试着把这两个数字分离开。

        我们依然先求出整个数组的亦或和sum,因为两个数字都是只出现一次的,所以sum的比特位必定有一位是1,因为sum可以被视为是两个数字亦或得到的,所以sum的每个为1的比特位对应的都是两个数字相异的比特位!这正好符合我们要将这唯二两个只出现一次的数字分离开的需求,所以接下来我们只需要提取出sum中的一个1,与整个数组相与就能把两个数字分离了,在常见位运算总结中,我们学到了提取最右侧1的方法:n&-n,所以我们可以轻松提取出sum的最右侧的1,根据这个作为条件进行判断即可。

        大家可能会奇怪,我只提到了分离这两个只出现一次的数字,那出现两次的呢?当然是因为对于出现两次的数字,在条件判断时,两个都会被分到其中的一组,则我们接下来对这两组元素分别求亦或和,就能分别得到两个只出现一次的数字了。

class Solution {
public:vector<int> singleNumber(vector<int>& nums) {int orsum = 0;for(auto num : nums){orsum ^= num;}int jud = (orsum == INT_MIN) ? orsum : orsum & (-orsum);int type1 = 0, type2 = 0;for(auto num : nums){if(num & jud){type1 ^= num;}else{type2 ^= num;}}return {type1, type2};}
};

3. 两整数之和

371. 两整数之和 - 力扣(LeetCode)

题目解析:

        本题乍一看无从下手,但是其实可以用我们总结的位运算操作来实现,还记得么,亦或运算实际上就是无进位相加,那么我们只要把两个数的亦或和加上他的进位就行了。

        至于进位,运算时仅当两个比特位都为1时才产生进位,是不是让我们联想到了与运算,仅当两个比特位都为1时才为1,由于进位的结果要加到更高的比特位上,所以我们将两个数的按位与之和左移一位,得到的就是本次相加的进位,接下来把进位、无进位相加结果相加即可。

        可是这不就又涉及到相加了吗?所以我们要重复这个流程,运算中不再有进位为止,这样就实现了不适用+、-进行两个整数的相加。

        还有一个细节问题,有符号整数在内存中是以补码的形式存储的,对于补码的运算规则是:

对于补码的移位运算,如果他的最高位与符号位是不一样的,左移的时候就会出现问题,举个例子:

此时我们发现,这个数左移时,符号位发生了变化,也就是说我们的左移操作是有问题的,为了避免这种情况,我们使用unsigned int来代替int进行储存变量

class Solution {
public:int getSum(int a, int b) {while(b){int x = a ^ b;unsigned int carry = (unsigned int)(a & b) << 1;a = x;b = carry;}return a;}
};

4. 只出现一次的数字(||)

LCR 004. 只出现一次的数字 II - 力扣(LeetCode)

题目解析:

        本题和前面两道只出现一次的数字一样,都可以用哈希表来非常轻松的解决,但是如果要求不使用额外空间来实现的话,就要用到位图了。

        依据题意,给定的元素可以被分为两类:出现一次的元素、出现三次的元素,对于整型数的32个比特位的每一位而言,可能的取值为0、1,则如果我们求这两类元素某一个比特位的和,由于第二类元素都出现了三次,假设nums范围为[0, n],则这类元素的和一定等于3 * m(m <= n).

        至于只出现一次的元素,在该比特位可能为0、1,所以对所有元素来说,该比特位的和可能值为:3 * m、3 * m + 1,对这个结果取模3,得到的可能结果为0、1,这正是只出现一次的元素的这一比特位,所以我们可以依法炮制,求出所有比特位。

        至于判断某个比特位是否为1、将某个比特位修改为1的方式,我们都在常见位运算总结部分提到了,所以直接上手写代码:

class Solution {
public:int singleNumber(vector<int>& nums) {int ret = 0;for(int i = 0; i < 32; i++){int sum = 0;for(auto &num : nums){if((num >> i) & 1) sum++;}// 如果比特位和模3余1,将返回值的该比特位修改为1if(sum % 3 == 1)ret |= (1 << i);}return ret;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/10730.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

手机在网状态多方面重要性

手机在网状态的重要性体现在多个方面&#xff0c;它是现代社会中人们保持联系、获取信息以及进行日常活动不可或缺的一部分。以下是一些关于手机在网状态重要性的详细解释&#xff1a; 通信联系&#xff1a; 手机是在现代社会中进行通信联系的主要工具。当手机处于在网状态时&…

【软考高项】四十四、高级项目管理

一、项目集管理 相关角色 项目集发起人、项目集指导委员会、项目集经理、其他影响项目集的干系人项目集管理绩效域 项目集战略一致性、项目集效益管理、项目集干系人参与、项目集治理和项目集生命周期管理 二、项目组合管理 项目组合经理角色 项目组合管理原…

Imitation Learning学习记录(理论例程)

前言 最近还是衔接着之前的学习记录&#xff0c;这次打算开始学习模仿学习的相关原理&#xff0c;参考的开源资料为 TeaPearce/Counter-Strike_Behavioural_Cloning: IEEE CoG & NeurIPS workshop paper ‘Counter-Strike Deathmatch with Large-Scale Behavioural Clonin…

java项目之汽车资讯网站源码(springboot+mysql+vue)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的汽车资讯网站。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 汽车资讯网站的主要使用者管…

Vue从入门到实战Day04

一、组件的三大组成部分&#xff08;结构/样式/逻辑&#xff09; 1. scoped样式冲突 默认情况&#xff1a;写在组件中的样式会全局生效 -> 因此很容易造成多个组件之间的样式冲突问题。 1. 全局样式&#xff1a;默认组件中的样式会作用到全局 2. 局部样式&#xff1a;可以…

LeetCode 138. 随机链表的复制

目录 1.原题链接&#xff1a; 2.结点拆分&#xff1a; 代码实现&#xff1a; 3.提交结果&#xff1a; 4.读书分享&#xff1a; 1.原题链接&#xff1a; 138. 随机链表的复制 2.结点拆分&#xff1a; ①.拷贝各个结点&#xff0c;连接在原结点后面&#xff1b; ②.处…

【MySQL】基本操作

欢迎来到Cefler的博客&#x1f601; &#x1f54c;博客主页&#xff1a;折纸花满衣 &#x1f3e0;个人专栏&#xff1a;MySQL 目录 &#x1f449;&#x1f3fb;创建和删除数据库&#x1f449;&#x1f3fb;数据库编码集和数据库校验集校验规则对数据库的影响 &#x1f449;&…

【1 bit 翻转+无任何保护】MidnightsunQuals 2021 BroHammer

前言 又是一道非常有意思的题目&#xff0c;其实笔者很喜欢这种跟页表、特权级等相关的题目&#xff08;&#xff1a;虽然大多都无法独立做出来&#xff0c;但是通过这些题目可以学到很多的东西 题目分析 内核版本&#xff1a;v4.17.0smap/smep/kpti/kaslr 全关 题目给了源…

laravel8 导入 excel常见问题

上传xls 或 xlsx 文件后&#xff0c;文件解析为 zip 格式&#xff0c;输入正常情况&#xff0c;不影响解析 里面的内容 遇到解析内容&#xff0c;解析为空的情况&#xff0c;可能是 因为excel 存在多个 Sheet1 造成&#xff0c;服务器不能解析一个 Sheet1 的情况&#xff0…

智慧停车场管理系统主要组成

智慧泊车场办理体系&#xff0c;完成了泊车办理过程中的车辆类型分类、出场时的车牌辨认、行进路线的引导、空余车位诱导&#xff0c;以及准备离场前的反向寻车和方便缴费等全部环节。这六个流程中&#xff0c;泊车场对车辆的办理&#xff0c;进步了泊车场的运行效率&#xff0…

数据分享—中国土壤有机质数据

土壤有机质数据是进行区域土地资源评价&#xff0c;开展自然地理研究常使用的数据&#xff0c;本期推文主要分享全国土壤有机质数据集。梧桐君会不定期分享地理信息数据&#xff0c;欢迎大家长期订阅。 数据来源 “万物土中生”&#xff0c;小编今天要分享的中国土壤有机质数…

牛客NC404 最接近的K个元素【中等 二分查找+双指针 Java/Go/PHP】

题目 题目链接&#xff1a; https://www.nowcoder.com/practice/b4d7edc45759453e9bc8ab71f0888e0f 知识点 二分查找&#xff1b;找到第一个大于等于x的数的位置idx;然后从idx开始往两边扩展Java代码 import java.util.*;public class Solution {/*** 代码中的类名、方法名、…

可观测性监控

1 目的 常见的监控&#xff0c;主要是以收集数据以识别异常系统效应为主&#xff0c;多是单个服务&#xff0c;相互独立的状态。 可观测性&#xff0c;希望调查异常系统效应的根本原因&#xff0c;能够把多个服务、中间件、容器等串联起来&#xff0c;同时柔和metrics、log、…

vue3.0(六) toRef,toValue,toRefs和toRow,markRaw

文章目录 toReftoValuetoRefstoRowmarkRawtoRef和toRefs的区别toRaw 和markRaw的用处 toRef toRef 函数可以将一个响应式对象的属性转换为一个独立的 ref 对象。返回的是一个指向源对象属性的 ref 引用&#xff0c;任何对该引用的修改都会同步到源对象属性上。使用 toRef 时需…

2024年最新趋势跨境电商平台开发需了解的新技术

随着数字化技术的不断演进和全球市场的日益融合&#xff0c;跨境电商平台开发将面临前所未有的挑战和机遇。为了更好地适应并引领这一发展&#xff0c;开发者需要密切关注2024年最新的技术趋势&#xff0c;以确保他们的平台能够在竞争激烈的市场中脱颖而出。本文将对跨境电商平…

HTML/CSS2

1.前置说明 HTML/CSS1 2.img元素 格式&#xff1a; <img src"图片地址" alt"占位文字" width"图片宽度" height"图片高度">其中alt是当图片加载失败时显示的文字 而且不同内核的浏览器显示出来的占位文字的效果也是不尽相同…

网安面经之文件上传漏洞

一、文件上传漏洞 1、文件上传漏洞的原理&#xff1f;危害&#xff1f;修复&#xff1f; 原理&#xff1a;⽂件上传漏洞是发⽣在有上传功能的应⽤中&#xff0c;如果应⽤程序对⽤户上传的⽂件没有控制或者存在缺陷&#xff0c;攻击者可以利⽤应⽤上传功能存在的缺陷&#xff…

从文本日志到图形日志 图形化编程桌面产品的突破

在一个宽敞明亮的会议室里&#xff0c;阳光透过落地窗洒在会议桌上。卧龙和凤雏相对而坐&#xff0c;他们的面前摆放着一些关于图形化编程桌面产品的资料和测试报告。会议室里的气氛紧张而热烈&#xff0c;团队成员们围坐在一起&#xff0c;专注地倾听着卧龙和凤雏的讨论。 卧龙…

单位学校FM调频电台直放站系统

随着教育技术的不断发展&#xff0c;校园广播系统的建设已成为现代学校必不可少的一部分。作为传统有线广播的有效补充&#xff0c;基于无线电信号传输的 FM 调频电台在学校的使用日益广泛&#xff0c;尤其是在紧急通知、日常信息传播及教学辅助等方面发挥着重要作用。为了增强…

韩顺平0基础学Java——第9天

p169-201 数组&#xff08;第六章&#xff09; 数组扩容 此时原来的数组arr被销毁。 牛蛙&#xff1a; 最后再加一句 SYstem。out。println&#xff08;“是否添加&#xff1f;”&#xff09;&#xff1b; char key myscanner。netx&#xff08;&#xff09;。charAT&…