【算法题解】3. 颠倒二进制位

news2024/11/16 23:31:41

文章目录

    • 题目
    • 解法一
      • 解题思路
      • 代码实现
      • 复杂度分析
    • 解法二
      • 解题思路
      • 代码实现
      • 复杂度分析
    • 解法三
      • 解题思路
      • 代码实现
      • 复杂度分析

题目

颠倒给定的 32 位无符号整数的二进制位。来自:leetcode

解法一

解题思路

  1. 取 n 的最低位,赋值给 ans 的最低位(ans 初始值位0)。
  2. 然后 n 向后移动一位,ans 向前移动一位,重复步骤1,直到取完 n 的所有位置。
    【算法题解3】 颠倒二进制位

代码实现

public class Solution {
    // you need treat n as an unsigned value
    public int reverseBits(int n) {
        int ans = n & 1;
        for(int i = 0; i < 31; i++){
            n = n >>> 1;
            ans = ans << 1;
            ans |= n & 1;
            
        }
        return ans;
    }
}

复杂度分析

时间复杂度 O ( n ) O(n) O(n):n 为二进制位的个数,这里为32。
空间复杂度 O ( 1 ) O(1) O(1)

解法二

解题思路

从 n 的最低位开始一位一位的取,然后将取到的值从 ans 的最高位开始一位一位的放,ans 的初始值为0。

n & 1 获取到 n 当前的最后一位,赋值给 ans 的最高位。然后将 n 右移 1 位,再用n & 1 就可以取到 n 的倒数第二位,以此类推,直到取完 n 的最高位的 1 之后,由于剩下的位置都是 0 ,和 ans 的初始值是一样的无需计算,则可以直接结束。

n = 0001 1100 1101 0100 为例,结果为:ans = 0010 1011 0011 1000

【算法题解3】 颠倒二进制位

代码实现

public class Solution {
    // you need treat n as an unsigned value
    public int reverseBits(int n) {
        
        int ans = 0;
        for(int i = 0; i < 32 && n != 0; i++){
            ans |= (n & 1) << (31 - i);
            n = n >>> 1;
        }
        
        return ans;
    }
}

复杂度分析

时间复杂度 O ( l o g n ) O(logn) O(logn):时间复杂度取决于 n 中最高为1的位置,即 logn 向下取整 + 1。
空间复杂度 O ( 1 ) O(1) O(1)

解法三

解题思路

使用分治的思想:

  1. 将32位二进制位分为2个16位的二进制位,分别颠倒2个16位的二进制位,然后再将颠倒后的2个16位数互换位置。
  2. 现在问题装换为颠倒一个16位二进制数,那么同样将16位二进制位分为2个8位的二进制位,分别颠倒2个8位的二进制位,然后再将颠倒后的2个8位数互换位置。
  3. 现在问题装换为颠倒一个8位二进制数,那么同样将8位二进制位分为2个4位的二进制位,分别颠倒2个4位的二进制位,然后再将颠倒后的2个4位数互换位置。
  4. 现在问题装换为颠倒一个4位二进制数,那么同样将4位二进制位分为2个2位的二进制位,分别颠倒2个2位的二进制位,然后再将颠倒后的2个2位数互换位置。
  5. 现在问题装换为颠倒一个2位二进制数,那么直接交换2个二进制位的位置即可,即交换二进制奇偶位。
    总结:要求颠倒32位 -> 需要先求颠倒16位 -> 需要先求颠倒8位 -> 需要先求颠倒4位 -> 需要先求颠倒2位(交换二进制奇偶位),一个递归的算法。

以16位 n = 0001 1100 1101 0100 为例,结果为:ans = 0010 1011 0011 1000

【算法题解3】 颠倒二进制位

代码实现

public class Solution {
    // you need treat n as an unsigned value
    public int reverseBits(int n) {
        
        //奇偶反转
        n = (n & 0x55555555) << 1 | (n >>> 1) & 0x55555555;

        //两两反转, 求的4位二进制的反转
        n = (n & 0x33333333) << 2 | (n >>> 2) & 0x33333333;

        // 每4个进行反转,求的8位二进制的反转
        n = (n & 0x0f0f0f0f) << 4 | (n >>> 4) & 0x0f0f0f0f;

        // 每8个进行反转,求的16位二进制的反转
        n = (n & 0x00ff00ff) << 8 | (n >>> 8) & 0x00ff00ff;

        // 每16个进行反转,求的32位二进制的反转
        n = (n & 0x0000ffff) << 16 | (n >>> 16) & 0x0000ffff;

        return n;
    }
}

复杂度分析

时间复杂度 O ( 1 ) O(1) O(1)
空间复杂度 O ( 1 ) O(1) O(1)

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

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

相关文章

mybatis 多对一查询的处理方式,1.按照查询嵌套处理(子查询),2、按照结果嵌套处理(连表查询)

多对一查询 1、实体类 Student实体类&#xff1a; public class Student { private int id; private String name; private Teacher teacher;//对象属性}Teacheer 实体类&#xff1a; public class Teacher { private int id; private String name;2、Mybatis配置文件mybatis…

FastDDS(4)安装步骤

eProsima Fast DDS for Linux的最新二进制安装版本可在eProssma网站找到。 eProsima Fast DDSSpecialized on high performance middleware. Check out our comparatives such as Apache Thrift vs Protocol Buffers vs Fast Buffers or ZMQ vs Fast RTPS.https://www.eprosim…

从一道经典题来弄懂Eventloop(搞不懂算我输)

前言 时间不知不觉来到了11月底&#xff0c;马上也要准备一下寒假的实习了。 最近打算把面试中的一些拦路虎给解决掉&#xff01;&#xff01; 先拿臭名昭著的Eventloop开刀~ 经典题 async function foo() {console.log(foo) } async function bar() {console.log(bar start…

RabbitMQ:基本消息模型

单生产单消费模型&#xff0c;即基本消息模型或简单消费模型&#xff0c;即完成基本的一对一消息转发。 RabbitMQ 单生产单消费模型主要有以下三个角色构成&#xff1a; 生产者&#xff08;producer/ publisher&#xff09;&#xff1a;一个发送消息的用户应用程序。消费者&…

JS面试题--JavaScript数据类型

数据类型 1.JavaScript有哪些数据类型&#xff0c;它们的区别&#xff1f; JavaScript共有八种数据类型&#xff0c;分别是 Undefined、Null、Boolean、Number、String、Object、Symbol、BigInt。 其中 Symbol 和 BigInt 是ES6 中新增的数据类型&#xff1a; ● Symbol 代表…

Linux系统基础——程序和进程

代码&#xff0c;程序&#xff0c;进程 特此说明: 刘超的趣谈linux操作系统是比较重要的参考资料&#xff0c;本文大部分内容和图片来源于这个专栏。 1 实验环境 运行一个demo&#xff0c;主要功能是主进程通过系统调用fork一个新的进程&#xff0c;子进程功能是加载二进制文件…

背包模型~

背包模型 概述 ​ 最长上升子序列&#xff1a;序列DP&#xff08;相邻两个被选择的有关系&#xff09; 背包问题&#xff1a;组合DP&#xff0c;在全局的考虑之下最小 f[i][j]&#xff1a;i 表示搞了多少&#xff0c;j 表示限制 集合&#xff1a;所有仅仅从前 i 个物品当…

论文推荐:CCNet用于语义分割的交叉注意力

CCNet&#xff0c; Transformer递归交叉自注意力&#xff0c;比非局部神经网络更有效。华中科技大学、地平线、ReLER 和伊利诺伊大学香槟分校联合研发 论文提出了交叉网络 (CCNet)&#xff0c;对于每个像素&#xff0c;CCNet 中的一个新的交叉注意力模块收集其交叉路径上所有像…

智慧路口:未来都市的智能节点

摘要交通路口是部署未来智慧城市的计算、通信和情报服务的最合适地点。需要收集和处理的大量数据&#xff0c;再加上隐私和安全问题&#xff0c;促使边缘计算范式的使用&#xff0c;这种范式与大都市的物理交叉路口很好地吻合。本文主要针对高带宽、低时延的应用&#xff0c;在…

2007-2022年消费者信心、满意度、预期指数月度数据(CCI、CEI、CSI、CGPI)

根据企业商品价格指数与消费者信心指数、消费者满意指数、消费者预期指数的月度数据&#xff0c;可以探究商品价格对消费者信心的影响作用和作用机制。 商品价格与消费者信心的三类细分指数均具有滞后二阶关联&#xff0c;其中&#xff0c;商品价格对对消费者预期指数的影响作…

IndexedDB的包装器JsStore - 实现登录功能及事务处理

JsStore是IndexedDB的包装器。它提供了简单的SQL像api&#xff0c;这是容易学习和使用。 IndexedDb查询可以在web worker内部执行&#xff0c;JsStore通过提供一个单独的worker文件来保持这种功能。 最近有位叫Pioneer网友一直在问我关于事务的实现方式&#xff0c;关于…

谷粒学院——Day13【微信扫描登录】

OAuth2 OAuth2的使用场景 一、OAuth2解决什么问题 1. OAuth2提出的背景 照片拥有者想要在云冲印服务上打印照片&#xff0c;云冲印服务需要访问云存储服务上的资源。 2. 图例 资源拥有者&#xff1a;照片拥有者。 客户应用&#xff1a;云冲印。 受保护的资源&#xff…

Python pandas库|任凭弱水三千,我只取一瓢饮(2)

上一篇链接&#xff1a; Python pandas库&#xff5c;任凭弱水三千&#xff0c;我只取一瓢饮&#xff08;2&#xff09;_Hann Yang的博客-CSDN博客 I~Q&#xff1a; Function10~25 Types[Function][9:25] [infer_freq, interval_range, isna, isnull, json_normalize, lres…

④【Maven】Maven的构建命令

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ Maven的构建命令一、注意二、&#x1f680;清理…

指针与数组的联系与区别【一万六千字超详解】

&#x1f3d6;️作者&#xff1a;malloc不出对象 ⛺专栏&#xff1a;《初识C语言》 &#x1f466;个人简介&#xff1a;一名双非本科院校大二在读的科班编程菜鸟&#xff0c;努力编程只为赶上各位大佬的步伐&#x1f648;&#x1f648; 目录前言数组的性质1.1 数组的内存布局1…

第四章 Spring的基础用法

文章目录 Spring的起源和背景理解依赖注入Spring容器理解Spring容器中的Bean管理容器中的Bean及其依赖注入自动装配使用Java类进行配置管理使用静态工厂、实例工厂创建Bean实例抽象Bean与子Bean容器中的工厂Bean管理Bean的生命周期几种特殊的依赖注入Spring的简化配置SpEL的功…

kali中间人攻击

数据来源 一、中间人攻击原理 1. 利用的ARP协议的漏洞 2. ARP协议原理&#xff1a; 1&#xff09;发送ARP广播请求目标MAC地址 2&#xff09;目标主机发送ARP单播应答&#xff0c;响应MAC地址 3. ARP攻击原理 攻击人通过发送虚假的ARP应答实现ARP缓存投毒!而受害人没有办法进行…

文件存储案例

1.文件存储-File文件存储案例 1.1.案例要求 1.2参考代码 文件读取 百度安全验证 文件最终的保存的目录在/data/data/user/0/包/files下&#xff08;1&#xff09;布局文件 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android&q…

kubernetes中使用Service反向代理外部服务

当我们的某个服务在外部集群的时候&#xff0c;但是又想k8s集群内的应用连接它&#xff0c;这是可以创建一个service&#xff0c;用service代理外部服务&#xff0c;然后集群内就能连接该service&#xff0c;从而间接的访问外部服务。 创建一个service代理外部的服务 创建一个…

代码挑战画 魔法圣诞树

一、前言 本文会基于C# GDI技术 从零到一 实现一颗 魔法圣诞树&#xff01;源码和素材在文末全部都有&#xff01; 二、魔法圣诞树 对于用代码画圣诞树&#xff0c;网上各种编程语言像python、css、java、c/c我们都有见到过了&#xff0c;那么在绘图方面&#xff0c;还有一位…