博客
关于我
【二进制求反序】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优化之BTree索引使用规则
查看>>
MySQL优化之推荐使用规范
查看>>
Webpack Critical CSS 提取与内联教程
查看>>
mysql优化概述(范式.索引.定位慢查询)
查看>>
MySQL优化的一些需要注意的地方
查看>>
mysql优化相关
查看>>
MySql优化系列-优化版造数据(存储过程+函数+修改存储引擎)-2
查看>>
MySql优化系列-进阶版造数据(load data statment)-3
查看>>
MySql优化系列-造数据(存储过程+函数)-1
查看>>
MySQL优化配置详解
查看>>
Mysql优化高级篇(全)
查看>>
mysql会员求积分_MySql-统计所有会员的最高前10次的积分和
查看>>
mysql会对联合索性排序优化_MySQL索引优化实战
查看>>