题解 | #HJ86 求最大连续bit数#

求最大连续bit数

http://www.nowcoder.com/practice/4b1658fd8ffb4217bc3b7e85a38cfaf2

C语言版本

#include <stdio.h>

int main() {
    int n, rangeMax, rangeCur;
    while(scanf("%d", &n) != EOF) {
        rangeMax = 0, rangeCur = 0;
        while (n > 0) {
           if ((n & 0x1) == 0x1) {
               rangeCur++;
               if (rangeCur > rangeMax) {
                   rangeMax = rangeCur;
               }
           } else {
               rangeCur = 0;
           }
           n >>= 1;
        }
        printf("%d\n", rangeMax);
    }
    return 0;
}

Python版本

while True:
    try:
        n = int(input())
        binStr = bin(n)[2:]
        temp = binStr.split('0')
        print(max(map(len, temp)))
    except:
        break
全部评论

相关推荐

10-13 13:49
南京大学 财务
饿魔:笑死我了,你简直是个天才
点赞 评论 收藏
分享
我的offer呢😡:这不才9月吗,26到明年毕业前能一直找啊,能拿下提前批,转正的,offer打牌的都是有两把刷子的,为什么非要跟他们比。如果别人是9本硕+金牌+好几段大厂实习呢?如果别人是双非通天代呢?如果别人是速通哥呢?,做好自己就行了,我们做不到他们一样提前杀死比赛,但晚点到终点也没啥关系吧
双非应该如何逆袭?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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