LeetCode 1680. 连接连续二进制数字(位运算)

文章目录

1. 题目

给你一个整数 n ,请你将 1 到 n 的二进制表示连接起来,并返回连接结果对应的 十进制 数字对 10^9 + 7 取余的结果。

示例 1:
输入:n = 1
输出:1
解释:二进制的 "1" 对应着十进制的 1 。

示例 2:
输入:n = 3
输出:27
解释:二进制下,123 分别对应 "1""10""11" 。
将它们依次连接,我们得到 "11011" ,对应着十进制的 27 。

示例 3:
输入:n = 12
输出:505379714
解释:连接结果为 "1101110010111011110001001101010111100" 。
对应的十进制数字为 118505380540 。
对 10^9 + 7 取余后,结果为 505379714 。
 
提示:
1 <= n <= 10^5

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/concatenation-of-consecutive-binary-numbers
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

class Solution {
public:
    int concatenatedBinary(int n) {
        long long ans = 0, mod = 1e9+7;
        vector<int> plus(32);
        for(int i = 1; i < 32; ++i)
            plus[i] = 1<<i;
        int bit;
        for(int i = 1; i <= n; ++i) 
        {
            bit = count(i);//这个数有多少位二进制
            ans = (ans*plus[bit] + i)%mod;//原数字乘以 2 的 bit 次方倍
        }
        return ans;
    }
    int count(int x)
    {
        int num = 1, count = 1;
        while(x > num)
        {
            num = num + (1 << count);
            count++;
        }
        return count;
    }
};

148 ms 6.5 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Michael阿明

如果可以,请点赞留言支持我哦!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值