博客
关于我
【二进制求反序】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 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 到底能不能放到 Docker 里跑?
查看>>
mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
查看>>
MySQL 加锁处理分析
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 参数 innodb_flush_log_at_trx_commit
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
MySQL 命令和内置函数
查看>>
mysql 四种存储引擎
查看>>
MySQL 在并发场景下的问题及解决思路
查看>>