【优选算法5】位运算经典算法面试题

1.基础位运算知识详解

2. 判定字符是否唯一

解法:位运算

每个比特位,标记是否出现过。

接下来:利用1.的基础位运算技巧,使每个比特位变成0 、1 ,最后得出结果。

3. 丢失的数字

思路1:哈希表

思路2:高斯求和

思路3:位运算:异或性质

用一个 ret 异或整个数组,然后异或 0 - n ,异或同乘除,满足交换律,不影响结果

并且,相同的数异或会抵消,异或0不变,最终留下唯一的那个"缺失"的数字

4. 两整数之和

思路:位运算

利用位运算,将二进制的表达式相加,就能达成要求。

根据1. ,两数异或,就是无进位相加。那进位怎么处理?模拟一下过程才知道:

按位与后,左移,就是需要的进位!

进位后,继续相异或,然后相与,直到进位为0:即b为0:

5. 只出现一次的数字 II

思路:位运算 + 比特位 % n

因为是计算nums中每个数字每一位相加,所以外层循环一次,统一右移动nums元素i位,判断是否为1,是的话就记数,记数完整个数组每一个比特位,再依次%3,看下列公式

是1,就改为1,是0就不变,因为提供的ret本身为0,提供其他的除外。

6.消失的两个数字

位运算 + 分组异或 分离答案

数组中与1-n全部异或一遍,得到的tmp就是a异或b的结果。

由于两数必定不同,异或的结果肯定有一位是不同的:

假设a那一位是1,b那一位是0:

按照异或的性质:位相异为1,找出第一个低位不同的,标记为diff

找到后,原数组的值被分为两类:

diff位为1的,归位a类,diff位为0的,归位b类。

这样,a,b就被分为两组,每组都只有一个不同的数字。问题就转化为只有一个不同的数字。

将他们全部与1-n中,diff为也为0或1的,一起异或。

就能抵消组中相同的,a组留下a,b组留下b

最后返回{a,b}

相关推荐
用户1474853079744 小时前
CodeX使用Skill生成游戏美术和音乐资源,一分钟入门
后端
假如让我当三天老蒯4 小时前
模块化:ES Module 与 CommonJS 的区别
前端·面试
Melody1234 小时前
用 abort 中断 AI 流式请求,我之前做错了
后端
沉默王二4 小时前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
onething3655 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 5 —— SSE 流式输出 + 打字机效果
人工智能·后端·全栈
一个做软件开发的牛马5 小时前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
码事漫谈5 小时前
AI 编程的「三体」架构:OpenSpec + Superpowers + GStack 如何让一个开发者撑起整个研发团队
后端
吃饱了得干活5 小时前
深入解析 OpenFeign:从重试、拦截到负载均衡的全维度实践
后端
onething3655 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 6 —— 业务完善 + 会话消息预览
人工智能·后端·全栈