LeetCode算法题-Reverse Bits(Java实现)
这是悦乐书的第185次更新,第187篇原创
01 看题和准备
今天介绍的是LeetCode算法题中Easy级别的第44题(顺位题号是190)。给定32位无符号整数,求它的反转位。例如:
输入:43261596
输出:964176192
说明:43261596以二进制表示为00000010100101000001111010011100,
964176192以二进制表示为00111001011110000010100101000000。
本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。
02 第一种解法
既然是做位运算,那么依次将原数从左往右移动一位,取出移动的位判断是0还是1,然后加到反转的结果上,并且反转的结果是从右往左移动一位,循环控制的次数为32次,因为是32位整数。
其中涉及到左移、右移、与(&)运算,与(&)运算的规则是相同的位上均为1时结果为1,否则结果为0,而左移、右移的规则就是从右往左补0和从左往右补0了。
public int reverseBits(int n) {
    int result = 0;
    for (int i=0; i<32; i++) {
        if ((n & 1) == 1) {
            result = (result << 1) + 1;
        } else {
            result = result << 1;
        }
        n = n >> 1;
    }
    return result;
}
03 第二种解法
可以将上面的步骤再简化下,进入循环时,无论原数右移出来的位是0还是1,都需要结果值左移一位,对此我们可以进行或(|)运算操作。
先将结果值左移一位,然后计算n和1的与(&)运算结果,再将两数做或(|)运算,如果n和1的与(&)运算结果为1,那么结果值就加1,为0就加0。
或(|)运算的规则是当两边操作数的位有一边为1时,结果为1,否则为0。
public int reverseBits2(int n) {
    int result = 0;
    for (int i = 0; i < 32; i++) {
        result = (result << 1) | (n & 1);
        n >>= 1;
    }
    return result;
}
04 第三种解法
先将原数转为二进制字符串,再利用StringBuilder的reverse方法得到反转的二进制字符串,再将二进制字符串变为整数返回。
public int reverseBits3(int n) {
    String inputBinary = this.decimalToBinary(n);
    String reversedInputBinary = new StringBuilder(inputBinary).reverse().toString();
    return this.binaryToDecimal(reversedInputBinary);
}
private String decimalToBinary(int n) {
    StringBuilder sb = new StringBuilder();
    while (Integer.compareUnsigned(n, 0) > 0) {
        sb.append(Integer.remainderUnsigned(n, 2));
        n = Integer.divideUnsigned(n, 2);
    }
    while (sb.length() < 32) {
        sb.append('0');
    }
    return sb.reverse().toString();
}
private int binaryToDecimal(String str) {
    int res = 0;
    for (char c: str.toCharArray()) {
        res *= 2;
        res += c == '0' ? 0 : 1;
    }
    return res;
}
05 第四种解法
利用包装类Integer自带的方法,reverse()方法即可反转原数。
public int reverseBits4(int n) {
    return Integer.reverse(n);
}
06 小结
算法专题目前已连续日更超过一个月,算法题文章44+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!
LeetCode算法题-Reverse Bits(Java实现)的更多相关文章
- LeetCode算法题-Reverse Words in a String III(Java实现)
		这是悦乐书的第259次更新,第272篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第126题(顺位题号是557).给定一个字符串,您需要反转句子中每个单词中的字符顺序,同 ... 
- LeetCode算法题-Reverse String II(Java实现)
		这是悦乐书的第256次更新,第269篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第123题(顺位题号是541).给定一个字符串和一个整数k,你需要反转从字符串开头算起的 ... 
- LeetCode算法题-Reverse String(Java实现)
		这是悦乐书的第205次更新,第217篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第73题(顺位题号是344).编写一个以字符串作为输入并返回字符串的函数.例如: 输入: ... 
- LeetCode算法题-Reverse Vowels of a String(Java实现-四种解法)
		这是悦乐书的第206次更新,第218篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第74题(顺位题号是345).编写一个函数,它将一个字符串作为输入,并仅反转一个字符串的 ... 
- LeetCode算法题-Reverse Linked List(Java实现)
		这是悦乐书的第192次更新,第195篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第51题(顺位题号是206).反转单链表.例如: 输入:1-> 2-> 3- ... 
- 【算法】LeetCode算法题-Reverse Integer
		这是悦乐书的第143次更新,第145篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第2题(顺位题号是7),给定32位有符号整数,然后将其反转输出.例如: 输入: 123 ... 
- LeetCode算法题-Heaters(Java实现)
		这是悦乐书的第239次更新,第252篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第106题(顺位题号是475).冬天来了!您在比赛期间的第一份工作是设计一个固定温暖半径 ... 
- LeetCode算法题-Sqrt(Java实现)
		这是悦乐书的第158次更新,第160篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第17题(顺位题号是69). 计算并返回x的平方根,其中x保证为非负整数. 由于返回类型 ... 
- LeetCode算法题-Prime Number of Set Bits in Binary Representation(Java实现)
		这是悦乐书的第311次更新,第332篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第180题(顺位题号是762).给定两个正整数L和R,在[L,R]范围内,计算每个整数的 ... 
随机推荐
- 如何将各种低版本的discuz版本升级到discuz x3.0
			最近在做discuz改版的项目,遇到了很多问题,相信很多拥有discuz论坛的版主,站长和程序猿在升级或改版discuz的过程中遇到过和我一样的问题,所以我开了一个discuz专栏,为大家讲解一下di ... 
- sql-索引的作用(超详细)
			(一)深入浅出理解索引结构 实际上,您可以把索引理解为一种特殊的目录.微软的SQL SERVER提供了两种索引:聚集索引(clustered index,也称聚类索引.簇集索引)和非聚集索引(nonc ... 
- https创建请求UrL报错: 未能为 SSL/TLS 安全通道建立信任关系
			1.项目中异常报错如下: 2.百度结果:原来是 网站没有使用SSL证书或者是SSl证书失效了的缘故. 3.具体解决方案如下: )导入命名空间 using System.Net.Security; us ... 
- software testing
			Software Testing Software testing is the process of evaluation a software item to detect differences ... 
- Javascript继承1:子类的的原型对象----类式继承
			//声明父类 function Parent(){ this.parentValue = true; this.favorites = ['看书'] } //为父类添加公有方法 Parent.prot ... 
- JavaScript碎片—函数闭包(模拟面向对象)
			经过这几天的博客浏览,让我见识大涨,其中有一篇让我感触犹深,JavaScript语言本身是没有面向对象的,但是那些大神们却深深的模拟出来了面向对象,让我震撼不已.本篇博客就是在此基础上加上自己的认知, ... 
- Spider-four
			计算机速度比较: CPU -> 寄存器 -> 缓存L1/L2/L3 -> 内存 -> 硬盘 -> 网卡 -> BIOS LMAP: Linux + MySQL + ... 
- [转]Javascript实现图片的预加载详解
			下面的函数实现了一个我们想要的最基本的图片预加载效果 function preloadimages(arr){ var newimages=[] var arr=(typeof arr!=" ... 
- vue.js插入dom节点的方式
			html代码: <div id="app"></div> js代码: var MyComponent = Vue.extend({ template: '& ... 
- 如何用ABP框架快速完成项目(2) - 快的定义!
			为什么要从快的角度来讲这系列课程呢? 因为快是一个很统一很清晰的标准. 所有人对时间都有一个统一清晰的概念. 比如说这系列课程会讲到的一个实例: 集成LinqToExcel, 用我的方法大概耗时 ... 
