题目 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;
}
相关推荐
牛客企业服务9 小时前
AI面试系统助手深度评测:6大主流工具对比分析
数据库·人工智能·python·面试·职场和发展·数据挖掘·求职招聘
爱coding的橙子21 小时前
每日算法刷题Day58:8.7:leetcode 单调栈5道题,用时2h
算法·leetcode·职场和发展
Monika Zhang21 小时前
【面试攻略】回答Java面试问题「挑战与解决方案」技巧
面试·职场和发展
BOB_BOB_BOB_1 天前
【ee类保研面试】数学类---概率论
面试·职场和发展·概率论·保研
爱coding的橙子1 天前
每日算法刷题Day57:8.6:leetcode 单调栈6道题,用时2h
算法·leetcode·职场和发展
爱吃生蚝的于勒1 天前
一文学会c++继承 组合
java·c语言·开发语言·数据结构·c++·算法·蓝桥杯
网安墨雨2 天前
2025金九银十软件测试面试题(800道)
软件测试·职场和发展
echo_pen2 天前
蓝桥杯----锁存器、LED、蜂鸣器、继电器、Motor
单片机·蓝桥杯
天才测试猿2 天前
什么是单元测试?
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
白白白鲤鱼2 天前
Vue2项目—基于路由守卫实现钉钉小程序动态更新标题
服务器·前端·spring boot·后端·职场和发展·小程序·钉钉