1. 题目
给你一个整数 n ,请你将 1 到 n 的二进制表示连接起来,并返回连接结果对应的 十进制 数字对 10^9 + 7 取余的结果。
示例 1:
输入:n = 1
输出:1
解释:二进制的 "1" 对应着十进制的 1 。
示例 2:
输入:n = 3
输出:27
解释:二进制下,1,2 和 3 分别对应 "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阿明),一起加油、一起学习进步!