【面试经典150 | 】颠倒二进制位
文章目录
- 写在前面
- Tag
- 题目来源
- 题目解读
- 解题思路
- 方法一:逐位颠倒
- 方法二:分治
- 写在最后
写在前面
本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更……
专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容进行回顾与总结,文章结构大致如下,部分内容会有增删:
- Tag:介绍本题牵涉到的知识点、数据结构;
- 题目来源:贴上题目的链接,方便大家查找题目并完成练习;
- 题目解读:复述题目(确保自己真的理解题目意思),并强调一些题目重点信息;
- 解题思路:介绍一些解题思路,每种解题思路包括思路讲解、实现代码以及复杂度分析;
- 知识回忆:针对今天介绍的题目中的重点内容、数据结构进行回顾总结。
Tag
【位运算】
题目来源
190. 颠倒二进制位
题目解读
将给定的 32 位无符号整数的二进制位进行颠倒。
解题思路
方法一:逐位颠倒
n 是一个 32 位的二进制数,我们从低位到高位枚举每一位,将其放置到答案 res 的合适位置。比如 n 的二进制位的第 i 位(从低位往高位数)放置到 res 的第 31 - i 位。当前枚举的比特位为当前 n & 1,在枚举完成当前位后,更新 n >>= 1 为下一个枚举做准备。
实现代码
class Solution {
public:uint32_t reverseBits(uint32_t n) {uint32_t ans = 0;for(int i = 0; i < 32; ++i){int lst = n & 1;lst <<= (31-i);ans |= lst;n >>= 1;}return ans;}
};
复杂度分析
时间复杂度: O ( l o g n ) O(logn) O(logn)。
空间复杂度: O ( 1 ) O(1) O(1)。
方法二:分治
还有一种分治的方法来实现 32 位无符号整数的二进制数颠倒。分治法又分为两种:
- 自上而下;
- 自下而上。
我们先来看一下自上而下进行分治,自上而下,首先对二进制数每 16 位为一组进行交换,接着是每 8 位一组交换、4 位一组交换、2 位一组交换直至 1 位二进制数为一组进行交换。通过这样的交换之后,就可以实现 32 位无符号整数的二进制数颠倒
怎么实现 16 位二进制数一组进行交换呢?通过位运算啊,将 n 右移 16 位,那么 n 将只会保留高位的 16 位;将 n 左移 16 位,那么 n 将只会保留低位的 16 位; (n >> 16) | (n << 16) 就完成了第一步的 “对二进制数每 16 位为一组进行交换”。
如图所示,我们以 8 位为一组进行交换,n & 0x00ff00ff 就可以得到 1 组和 3 组位置的 8 位二进制数,我们再对 n & 0x00ff00ff 左移八位,就将 1 组和 3 组位置的 8 位二进制数移动到了 0 组和 2 组。我们现将 n 左移 8 位,然后与上 0x00ff00ff 就将 0 组和 2 组位置的 8 位二进制数移动到了 1 组和 3 组。最后将这两种操作或上就完成了以 8 位为一组进行交换。
类似的可以完成以 4、2、1 为一组的交换操作。
以上遍历自上而下的分治方法。自下而上的分治操作就是先以 1 为一组进行交换,然后再分别以 2、4、16 为一组进行交换。需要注意的是每种交换单位对应需要与上的二进制数。
以下代码给出的是自下而上的分治代码,自上而下的分治代码就是自下而上的分治代码顺序颠倒过来。方法二也是 【进阶】的解决方案。
实现代码
class Solution {
private:const uint32_t M1 = 0x55555555;const uint32_t M2 = 0x33333333;const uint32_t M4 = 0x0f0f0f0f;const uint32_t M8 = 0x00ff00ff;
public:uint32_t reverseBits(uint32_t n) {n = n >> 1 & M1 | (n & M1) << 1;n = n >> 2 & M2 | (n & M2) << 2;n = n >> 4 & M4 | (n & M4) << 4;n = n >> 8 & M8 | (n & M8) << 8;return n >> 16 | n << 16;}
};
复杂度分析
时间复杂度: O ( 1 ) O(1) O(1)。
空间复杂度: O ( 1 ) O(1) O(1)。
写在最后
如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。
如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。
最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。
相关文章:
【面试经典150 | 】颠倒二进制位
文章目录 写在前面Tag题目来源题目解读解题思路方法一:逐位颠倒方法二:分治 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更…… 专栏内容以分析题目为主,并附带一些对于…...
十分钟了解自动化测试
自动化测试 自动化测试的定义:使用一种自动化测试工具来验证各种软件测试的需求,它包括测试活动的管理与实施、测试脚本的开发与执行。 自动化测试只是测试工作的一部分,是对手工测试的一种补充; 自动化测试绝不能代替手工测试;多数情况下&…...
Redis配置文件
Redis可以在没有配置文件的情况下使用内置的默认配置启动,但是这种设置仅推荐用于测试和开发。 配置Redis的正确方法是提供一个Redis配置文件,通常称为 redis.conf 。 通过命令行传递参数启动 你也可以直接使用命令行传递Redis配置参数。这对于测试非…...
[量化投资-学习笔记009]Python+TDengine从零开始搭建量化分析平台-KDJ
技术分析有点像烹饪,收盘价、最值、成交量等是食材;均值,移动平均,方差等是烹饪方法。随意组合一下就是一个技术指标。 KDJ又称随机指标(随机这个名字起的很好)。KDJ的计算依据是最高价、最低价和收盘价。…...
Activiti6工作流引擎:Form表单
表单约等于流程变量。StartEvent 有一个Form属性,用于关联流程中涉及到的业务数据。 一:内置表单 每个节点都可以有不同的表单属性。 1.1 获取开始节点对应的表单 Autowired private FormService formService;Test void delopyProcess() {ProcessEngi…...
Fortran 中的指针
Fortran 中的指针 指针可以看作一种数据类型 指针存储与之关联的数据的内存地址变量指针:指向变量数组指针:指向数组过程指针:指向函数或子程序指针状态 未定义未关联 integer, pointer::p1>null() !或者 nullify(p1) 已关联 指针操作 指…...
第七章 块为结构建模 P4|系统建模语言SysML实用指南学习
仅供个人学习记录 这部分感觉很模糊,理解的不好,后面的图也没画了,用到的时候再来翻书 应用端口实现接口建模 端口port表示了块边界上的一个访问点,也可以是由该块分类的任何组成或引用边界上的可访问点。一个块可以有多个端口规…...
提升中小企业效率的不可或缺的企业云盘网盘
相比之大型企业,中小型企业在挑选企业云盘工具更注重灵活性和成本。那么市面上有哪些企业云盘产品更适合中小企业呢? 说起中小企业不能错过的企业云盘网盘,Zoho Workdrive企业云盘绝对榜上有名! Zoho Workdrive企业云盘为用户提…...
Web 安全之时序攻击 Timing Attack 详解
目录 什么是 Timing Attack 攻击? Timing Attack 攻击原理 Timing Attack 攻击的几种基本类型 如何防范 Timing Attack 攻击 小结 什么是 Timing Attack 攻击? Timing Attack(时序攻击)是一种侧信道攻击(timing s…...
【objectarx.net】定时器的使用
【objectarx.net】定时器的使用...
C++:容器list的介绍及使用
目录 1.list的介绍及使用 1.1 list的介绍 1.2 list的使用 1.2.1 list的构造 1.2.2 list iterator 的使用 1.2.3 list capacity 容量 1.2.4 list element access 访问list元素 1.2.5 list modifiers 修改 1.2.6 迭代器失效 1.list的介绍及使用 1.1 list的介绍 C官网 …...
元核云亮相金博会,智能质检助力金融合规
11月初,第五届中新(苏州)数字金融应用博览会|2023金融科技大会在苏州国际博览中心举办,围绕金融科技发展热点领域及金融行业信息科技领域重点工作,分享优秀实践经验,探讨数字化转型路径与未来发…...
Harmony 应用开发的知识储备
Harmony 应用开发的知识储备 前言正文一、DevEco Studio版本二、手机版本① 环境变量 三、API版本四、开发语言五、运行调试 前言 这里先说明一点,如果你对Android应用开发很熟悉,那么做Harmony应用开发也可以驾轻就熟,只不过在此之前你需要知…...
(层次遍历)104. 二叉树的最大深度
原题链接:(层次遍历)104. 二叉树的最大深度 思路: 使用层序遍历模板,遍历每一层 hight1 返回hight即可 全代码: class Solution { public:int maxDepth(TreeNode* root) {queue<TreeNode*> que;int hight 0;if(root NU…...
【api_fox】ApiFox简单操作
1、get和post请求的区别?2、接口定义时的传参格式?3、保存接口文档 apifox当中接口文档的设计和接口用例的执行是分开的。 1、get和post请求的区别? 2、接口定义时的传参格式? 3、保存接口文档 就生成如下的接口文档。...
给CAD中添加自定义菜单CUIX
本文以AutoCAD2020为例,介绍如何添加自定义菜单。 打开AutoCAD2020,在命令行执行CUI并回车,出现菜单 进入菜单编辑界面 点击传输,然后新建 在菜单上右键,添加自定义菜单 点击保存,即可存为cuix文件。之后…...
Qt重启windows服务
日常开发中,会遇到改变某个服务的参数,并进行重启(例如Redis断电恢复机制) 需要程序拥有UAC权限,并且调用如下API才能对windows服务进行重启: #include "windows.h"#pragma comment(lib, "…...
OD机考真题:宜居星球改造计划
题目 2XXX 年,人类通过对火星的大气进行宜居改造分析,使得火星已在理论上具备人类宜居的条件; 由于技术原因,无法一次性将火星大气全部改造,只能通过局部处理形式; 假设将火星待改造的区域为 row * column_row_∗_column_ 的网格,每个网格有 3 个值,宜居区、可改造区、…...
Python每日练习:20个常用代码,初学者也可以自己实现!
文章目录 前言20个代码1.重复元素判定2.字符元素组成判定3.内存占用4.字节占用5.打印 N 次字符串6.大写第一个字母7.分块8.压缩9.解包10.链式对比11.逗号连接12.元音统计13.首字母小写14.展开列表15.列表的差16.通过函数取差17.链式函数调用18.检查重复项19.合并两个字典20.将两…...
GitHub Copilot Chat将于12月全面推出;DeepLearning.AI免费新课
🦉 AI新闻 🚀 GitHub Copilot Chat将于12月全面推出,提升开发者的生产力 摘要:GitHub宣布将于12月全面推出GitHub Copilot Chat,这是GitHub Copilot的一个新功能,旨在帮助开发者编写代码。它能够集成到开…...
HEIF Utility:为Windows用户打通苹果照片格式壁垒的3大核心方案
HEIF Utility:为Windows用户打通苹果照片格式壁垒的3大核心方案 【免费下载链接】HEIF-Utility HEIF Utility - View/Convert Apple HEIF images on Windows. 项目地址: https://gitcode.com/gh_mirrors/he/HEIF-Utility 你是否曾经从iPhone传输照片到Window…...
AGI不再黑箱,区块链不再空转:2026奇点大会公布的7层可验证智能体架构(VIA-7),附开源参考实现链接
第一章:2026奇点智能技术大会:AGI与区块链 2026奇点智能技术大会(https://ml-summit.org) AGI系统与去中心化共识的协同演进 在2026奇点智能技术大会上,核心议题之一是通用人工智能(AGI)如何与区块链底层范式深度融合…...
SystemVerilog task避坑指南:自动存储、时序控制和多返回值的最佳实践
SystemVerilog task避坑指南:自动存储、时序控制和多返回值的最佳实践 SystemVerilog中的task是硬件描述和验证工程师日常工作中不可或缺的工具。它不仅能封装复杂的行为逻辑,还能通过参数化、递归调用等特性大幅提升代码复用率。然而,在实际…...
技术空对象的默认行为与空值处理
技术空对象的默认行为与空值处理 在软件开发中,空对象(Null Object)和空值(Null或None)的处理是常见但容易被忽视的问题。空对象通常指代一个无实际意义的占位符,而空值则可能引发程序崩溃或逻辑错误。合理…...
手势识别实战:从Light-HaGRID轻量数据集到多平台部署
1. 手势识别与Light-HaGRID数据集入门 第一次接触手势识别项目时,我被海量数据需求吓到了。直到发现Light-HaGRID这个轻量数据集,才明白原来入门可以这么简单。这个数据集最吸引我的地方在于,它把原始716GB的HaGRID数据压缩到18GB࿰…...
如何高效实现网站内容本地化备份:WebSite-Downloader实战指南
如何高效实现网站内容本地化备份:WebSite-Downloader实战指南 【免费下载链接】WebSite-Downloader 项目地址: https://gitcode.com/gh_mirrors/web/WebSite-Downloader 在信息时代,重要网页随时可能消失或改版,你是否曾遇到过急需访…...
终极指南:如何快速定位Windows热键冲突问题的罪魁祸首
终极指南:如何快速定位Windows热键冲突问题的罪魁祸首 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否曾…...
OBS Composite Blur插件:直播模糊特效的终极解决方案
OBS Composite Blur插件:直播模糊特效的终极解决方案 【免费下载链接】obs-composite-blur A comprehensive blur plugin for OBS that provides several different blur algorithms, and proper compositing. 项目地址: https://gitcode.com/gh_mirrors/ob/obs-c…...
Applite:3步告别终端命令,用图形界面轻松管理macOS应用
Applite:3步告别终端命令,用图形界面轻松管理macOS应用 【免费下载链接】Applite User-friendly GUI macOS application for Homebrew Casks 项目地址: https://gitcode.com/gh_mirrors/ap/Applite 还在为繁琐的终端命令而头疼吗?macO…...
数据库连接池 HikariCP 怎么调优?一次讲清最大连接数、超时参数与线上排查思路
数据库连接池 HikariCP 怎么调优?一次讲清最大连接数、超时参数与线上排查思路 大家好,我是一名有 4 年工作经验的 Java 后端开发。 很多项目的数据库连接池配置,基本都是抄一份就上了。 但真正到了线上,高峰期数据库问题往往不只…...
