题解 | #2的幂#

2的幂

https://www.nowcoder.com/practice/4a04240fd2be4e1287aab4af067f6d8f

分享一个很简单易懂的思路
既然是2的幂次,那么思考从1到1e9到底有多少个2的幂次
相信c语言int范围类型里给我们答案了,1e9就是比int范围小一点
所以就是2^32-1就是2的31次方
那么直接从1开始不断乘31次即可~这里用位运算会比乘快很多哦!小tips
不信自己可以试试,具体看代码啦,注意要先判断,不然会漏1的情况
class Solution {
public:
    bool poweroftwo(int n) {
        // write code here
        int ans=1;
        for(int i=0;i<31;i++){
            if(ans==n) return true;
            ans<<=1;
        }
        return false;
    }
};


全部评论

相关推荐

03-01 21:45
中北大学 golang
孤蓝长空:请你说一下为什么你用websocket而不是http,请你说一下什么是rpc,为什么用rpc,你的rpc的传输协议是JSON,xml还是什么 请你描述一下你的鉴权流程(完整的) 我问的是第二个项目,随便问的哈哈哈
开工第一帖
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务