题目 3330: 蓝桥杯2025年第十六届省赛真题-01 串

题目 3330: 蓝桥杯2025年第十六届省赛真题-01 串

时间限制: 2s 内存限制: 192MB 提交: 310 解决: 24

题目描述

给定一个由 0, 1, 2, 3 · · · 的二进制表示拼接而成的长度无限的 01 串。

其前若干位形如 011011100101110111 · · · 。

请求出这个串的前 x 位里有多少个 1 。

输入格式

输入的第一行包含一个正整数 x 。

输出格式

输出一行包含一个整数表示答案。

样例输入复制

7

样例输出复制

5

提示

【样例说明】

给定的串的前 7 位为 0110111 。

【评测用例规模与约定】

对于 60% 的评测用例,x ≤ 106 ;

对于所有评测用例,1 ≤ x ≤ 1018 。

1.分析

1个测试点没过,记录一下这种算法。

如果你们能该全过,求告诉!

2.代码

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>
#include<cmath>
using namespace std;
typedef long long LL;
LL x, re, t=1;
void check(LL i) {
    vector<int> v;
    while (i) {
        v.push_back(i % 2);
        i /= 2;
    }
    for (int i = v.size() - 1; i >= 0&&x>0; i--,x--) {
        if (v[i] == 1) re++;
    }
}
int main() {
    cin >> x;
    x--;
    while (x >= t * pow(2, t - 1)) {
        re += (t - 1) * pow(2, t - 2) + pow(2, t - 1);
        x -= t * pow(2, t - 1);
        t++;
    }
    for ( LL i = pow(2, t - 1); x>0; i++) {
        check(i);
    }
    cout << re << endl;
    return 0;
}
相关推荐
学历真的很重要2 小时前
Claude Code 万字斜杠命令指南
后端·语言模型·面试·职场和发展·golang·ai编程
萘柰奈2 小时前
LeetCode刷题记录----62.不同路径(Medium)
算法·leetcode·职场和发展
天才测试猿2 小时前
Python常用自动化测试框架—Pytest详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·pytest
测试老哥14 小时前
Python+selenium自动化生成测试报告
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
2351615 小时前
【LeetCode】3. 无重复字符的最长子串
java·后端·算法·leetcode·职场和发展
微笑尅乐16 小时前
神奇的位运算——力扣136.只出现一次的数字
java·算法·leetcode·职场和发展
吃着火锅x唱着歌17 小时前
LeetCode 3105.最长的严格递增或递减子数组
算法·leetcode·职场和发展
测试199817 小时前
Web自动化测试之测试用例流程设计
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
吃着火锅x唱着歌17 小时前
LeetCode 2765.最长交替子数组
算法·leetcode·职场和发展
墨染点香18 小时前
LeetCode 刷题【91. 解码方法】
算法·leetcode·职场和发展