蓝桥杯2024B组

[蓝桥杯 2024 国 B] 立定跳远

二分查找

二分查找:通常用于在有序集合快速查找到目标值。但当问题满足以下条件时,也可以使用二分查找来解决最优化问题:

解的范围明确有序:需要确定解的可能范围,且该范围具有单调性。例如,当某个候选值满足条件时,更大(或更小)的值也一定满足条件。

存在高效的验证方法:能够快速判断某个候选值是否满足问题的条件。

cpp 复制代码
#include <iostream>
using namespace std;

int n, m;
int a[100010]; // 确保数组足够大以容纳原点和所有检查点

int check(int x) {
    int ans = 0;
    for (int i = 1; i <= n; i++) { // 处理所有相邻差,包括原点到第一个检查点
        int d = a[i] - a[i - 1];
        if (d > x) { // 仅当距离超过x时才需要分割
            ans += (d % x == 0) ? (d / x - 1) : (d / x);
        }
    }
    return ans <= m + 1; // 允许通过爆发技能减少一个检查点需求
}

int main() {
    cin >> n >> m;
    a[0] = 0; // 将原点0作为第一个元素
    for (int i = 1; i <= n; i++) {
        cin >> a[i]; // 输入的检查点存储在a[1]到a[n]
    }
    int l = 1, r = 1e8; // 左边界从1开始,避免除以零错误
    while (l < r) {
        int mid = (l + r) >> 1;
        if (check(mid)) {
            r = mid;
        } else {
            l = mid + 1;
        }
    }
    cout << l << endl;
    return 0;
}

B: 小球反弹

下述代码分别使用cout和printf输出

cout用了科学计数法,其结果相同
要让 cout 的输出格式与 printf 一致(例如,以浮点数形式显示所有小数位),你需要手动控制 cout 的小数位数和输出格式(禁用科学计数法)。cout << fixed << setprecision(6) << value << endl; // 强制6位小数

cpp 复制代码
#include <iostream>
#include <vector>
#include<set>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <climits>  // 包含INT_MAX常量
#include <cctype>
#include<map>
using namespace std;

int main(){
	for(long long i=2;i<10000;i+=2){
		for(long long j=2;j<10000;j+=2){
			if(343720*i*17==233333*j*15){
				cout<<sqrt((343720*i)*(343720*i)+(233333*j)*(233333*j))<<endl;
				printf("%f",sqrt((343720*i)*(343720*i)+(233333*j)*(233333*j)));
				return 0;
			}
		}
	}
return 0;
}

好数

cpp 复制代码
#include <iostream>
#include <vector>
#include<set>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <climits>  // 包含INT_MAX常量
#include <cctype>
#include<map>
using namespace std;

int main(){
	int n,ans=0;
	cin>>n;
	for(int i=1;i<=n;i++){
		int num=i;
		for(int j=1;num;j++){
			if((num%10)%2==j%2)
				num/=10;
			else break; 
		}
		if(num==0)ans+=1;
	}
	cout<<ans;
return 0;
}

R 格式

cpp 复制代码
#include <iostream>
#include <vector>
#include<set>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <climits>  // 包含INT_MAX常量
#include <cctype>
#include<map>
using namespace std;
int n;
double t;
int main(){
	cin>>n>>t;
	cout<<(unsigned long long)(t*(1ULL<<n)+0.5); 
return 0;
}

只能通过一半用例

相关推荐
XH华9 小时前
备战蓝桥杯,第九章:结构体和类
学习·蓝桥杯
园小异9 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
Epiphany.55612 小时前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
YuTaoShao13 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
Ll130452529817 小时前
Leetcode二叉树part4
算法·leetcode·职场和发展
夏鹏今天学习了吗19 小时前
【LeetCode热题100(99/100)】柱状图中最大的矩形
算法·leetcode·职场和发展
_OP_CHEN20 小时前
【算法基础篇】(五十八)线性代数之高斯消元法从原理到实战:手撕模板 + 洛谷真题全解
线性代数·算法·蓝桥杯·c/c++·线性方程组·acm/icpc·高斯消元法
仰泳的熊猫20 小时前
题目1453:蓝桥杯历届试题-翻硬币
数据结构·c++·算法·蓝桥杯
零售ERP菜鸟1 天前
范式革命:从“信息化”到“数字化”的本质跃迁
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
网络安全-杰克1 天前
2026面试自动化测试面试题【含答案】
自动化测试·软件测试·面试·职场和发展