博客
关于我
【二进制求反序】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/

你可能感兴趣的文章
Nginx负载均衡(upstream)
查看>>
nginx转发端口时与导致websocket不生效
查看>>
Nginx运维与实战(二)-Https配置
查看>>
Nginx部署_mysql代理_redis代理_phoenix代理_xxljob代理_websocket代理_Nacos代理_内网穿透代理_多系统转发---记录021_大数据工作笔记0181
查看>>
nginx部署本地项目如何让异地公网访问?服务器端口映射配置!
查看>>
Nginx配置HTTPS服务
查看>>
Nginx配置Https证书
查看>>
Nginx配置http跳转https
查看>>
Nginx配置ssl实现https
查看>>
nginx配置ssl证书https解决公网ip可以访问但是域名不行的问题
查看>>
Nginx配置TCP代理指南
查看>>
NGINX配置TCP连接双向SSL
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
查看>>
nginx配置中的服务器名称
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
nginx配置全解
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置后台网关映射路径
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>