博客
关于我
【二进制求反序】LeetCode初试验_Reverse Bits
阅读量:209 次
发布时间:2019-02-28

本文共 901 字,大约阅读时间需要 3 分钟。

今天在网上看到有人说LeetCode很适合刷题,于是我就随手点了一道题看看。

Reverse Bits

 
Total Accepted: 12829 
Total Submissions: 47004

Reverse bits of a given 32 bits unsigned integer.

For example, given input 43261596 (represented in binary as 00000010100101000001111010011100), return 964176192 (represented in binary as00111001011110000010100101000000).

Follow up:
If this function is called many times, how would you optimize it?

Related problem: 

这是一道很普通的二进制求反序二进制的问题,脑中想到的自然还是和十进制一样取余放到新的数里去,然后乘以十循环到底。

然后在Discuss看到一个3ms的算法,对哦~毕竟是二进制,那么因材制宜采用二进制的各种运算自然会快得多!

二进制有哪些在底层来说是基础运算呢? 逻辑运算,左右移。

又因为uint32_t是一个32位的数,所以不管这数原先是多少都呆胶布~

res=(res<<1)^(n&1)  容器左移一格然后把移出来的末位放上原数n的末尾

n>>=1 然后原数的末尾就不需要咯,右移扔掉~

Code:

class Solution {public:    uint32_t reverseBits(uint32_t n) {        int i;        uint32_t res=0;        for(i=0;i<32;i++)        {            res=(res<<1)^(n&1);            n>>=1;        }        return res;    }};

转载地址:http://epwi.baihongyu.com/

你可能感兴趣的文章
MySql的创建数据表、约束、外键约束的创建修改删除、级联操作
查看>>
MySQL的删除修改的实验目的_基础篇 - 数据库及表的修改和删除
查看>>
MySQL的四大隔离级别,你都知道哪些?
查看>>
MySQL的四种事务隔离级别
查看>>
MySQL的基本命令
查看>>
Mysql的备份与恢复类型
查看>>
mysql的大小写对性能的影响问题
查看>>
mysql的密码管理、mysql初始密码查找、密码修改、mysql登录
查看>>
mysql的常见八股文面试题
查看>>
MySQL的常见命令
查看>>
mysql的引擎以及优缺点_MySQL有哪些存储引擎,各自的优缺点,应用场景-阿里云开发者社区...
查看>>
MySQL的操作:
查看>>
mysql的数据类型有哪些?
查看>>
MYSQL的最左匹配原则的原理讲解
查看>>
mysql的语法规范
查看>>
MySql的连接查询
查看>>
mysql的配置文件参数
查看>>
MySQL的错误:No query specified
查看>>
mysql监控工具-PMM,让你更上一层楼(上)
查看>>
mysql监控工具-PMM,让你更上一层楼(下)
查看>>