蓝桥杯复习之二分法与前缀和

news/2024/7/7 21:02:18

题目:最佳牛围栏

题目链接:https://www.acwing.com/problem/content/104/

题意:农夫约翰的农场由 N 块田地组成,每块地里都有一定数量的牛,其数量不会少于 1 头,也不会超过 2000 头。

      约翰希望用围栏将一部分连续的田地围起来,并使得围起来的区域内每块地包含的牛的数量的平均值达到最大。

      围起区域内至少需要包含 F 块地,其中 F 会在输入中给出。

      在给定条件下,计算围起区域内每块地包含的牛的数量的平均值可能的最大值是多少?

思路:
    找平均值/最小(大)值的最大(小)值,往二分答案方向想,二分答案的模板见代码。我们在每一次假设答案的计算过程中,将数组都减去mid方便计算(也就是只要存在满足条件同时大于0的字段就可以返回true了)
    因为是找连续的一段,我们用前缀和优化计算,假设前缀和数组为pre,只要存在pre[j]-pre[i]>=0且j-i>=f就可以返回true了。

#include<bits/stdc++.h>

using namespace std;

using ll = long long;
const ll N = 100005;
const ll mod = 1e9 + 7;
const int maxn = 2005;
int gcd(int a, int b) {
	return b ? gcd(b, a % b) : a;
}

int n, f;
int a[N];
double pre[N];

bool check(double m) {
	for (int i = 1; i <= n; i++) {
		pre[i] = pre[i - 1] + a[i] * 1.0 - m;
	}
	
	double minn = 0;

	for (int i = 0, j = f; j <= n; j++, i++) {
		minn = min(minn, pre[i]);
		if (pre[j] >= minn)
			return true;
	}
	return false;
}

void solve() {
	cin >> n >> f;

	for (int i = 1; i <= n; i++) {
		cin >> a[i];
	}

	double l = 1, r = 2002;
	while (r-l>=1e-5) {
		double mid = (l + r) / 2;
		if (check(mid)) {
			l = mid;
		}
		else
			r = mid;
	}
	cout << (int)(r * 1000) << '\n';

}
		

signed main() {

	ios::sync_with_stdio(false);
	cin.tie(0);
	std::cout.tie(0);

	int t = 1; //cin >> t;
	while (t--)
		solve();

	return 0;
}


http://lihuaxi.xjx100.cn/news/2063044.html

相关文章

40-组合总和2(回溯算法)

题目 给定一个候选人编号的集合 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字在每个组合中只能使用 一次 。 注意&#xff1a;解集不能包含重复的组合。 示例 1: 输入: candidates [10,1,2,7,6…

06 OpenCV增加图像的对比度

文章目录 理论API代码 理论 图像变换可以看作如下&#xff1a; 像素变换 – 点操作邻域操作 – 区域 调整图像亮度和对比度属于像素变换-点操作 API saturate_cast(value)确保值大小范围为0~255之间Mat.at(y,x)[index]value 给每个像素点每个通道赋值 代码 #include <…

2024免费mac苹果电脑的清理和维护软件CleanMyMac X

对于 Mac 用户来说&#xff0c;电脑的清理和维护是一件让人头疼的事情。但是&#xff0c;有了 CleanMyMac X&#xff0c;这一切都将变得轻松愉快。CleanMyMac X 是一款专为 Mac 设计的电脑清理软件&#xff0c;它以其强大的功能和简单的操作&#xff0c;让无数用户为之倾倒。 C…

【未完结】nginx+hexo搭建个人网站真实体验!

自从之前学习Vue和SSM的时候写了个博客项目之后&#xff0c;就特别想做一个自己的博客网站。可能是出于拖延心理以及各种任务安排时间繁忙&#xff0c;一直没有抽时间去弄。博客笔记基本上都是直接使用csdn写的&#xff0c;除此之外&#xff0c;还经常在这些网站上写笔记&#…

蓝桥OJ 2942数字王国之军训排队 DFS剪枝

蓝桥OJ 2942数字王国之军训排队 #include<bits/stdc.h> using namespace std;const int N 15;//最多10队 int a[N], n; vector<int>v[N];//二维数组 v[i]记录队伍i中所有人的编号bool dfs(int cnt, int dep) {if (dep n1){//判断合法性for (int i 1; i < n; …

未来技术发展与情绪消除的可能性——探索人工智能对情绪调控的新路径

随着科技的飞速进步&#xff0c;特别是人工智能(AI)和神经科学领域的突破&#xff0c;关于是否存在一种未来机器能够消除人类情绪的问题引发了广泛的社会讨论与伦理思考。本文旨在探讨这一设想的可能性、潜在影响以及相关伦理挑战。 首先&#xff0c;从技术角度看&#xff0c;科…

5.40 BCC工具之ustat.py解读

一,工具简介 ustat是一个类似于“top”的工具,用于监控高级语言中的事件。它为每个使用Java、Node、Perl、PHP、Python、Ruby和Tcl运行时的进程打印关于垃圾收集、方法调用、对象分配以及各种其他事件的统计信息。 二,代码示例 #!/usr/bin/pythonfrom __future__ import …

腾讯云幻兽帕鲁游戏存档迁移教程,本地单人房迁移/四人世界怎么迁移存档?

腾讯云幻兽帕鲁游戏存档迁移的方法主要包括以下几个步骤&#xff1a; 登录轻量云控制台&#xff1a;首先&#xff0c;需要登录到轻量云控制台&#xff0c;这是进行存档迁移的前提条件。在轻量云控制台中&#xff0c;可以找到接收存档的服务器卡片&#xff0c;并点击进入实例详情…