当前位置:首页 > 题解目录 > 正文内容

【题解】均分蛋糕

亿万年的星光4年前 (2022-03-19)题解目录16725

【题目描述】

小明的生日要到了!根据习俗,他需要将一些派分给大家。

他有 N 个不同口味、不同大小的派。有 F 个朋友会来参加我的派对,每个人会拿到一块派(必须一个派的一块,不能由几个派的小块拼成;可以是一整个派)。

我的朋友们都特别小气,如果有人拿到更大的一块,就会开始抱怨。因此所有人拿到的派是同样大小的(但不需要是同样形状的),虽然这样有些派会被浪费,但总比搞砸整个派对好。当然,我也要给自己留一块,而这一块也要和其他人的同样大小。

请问我们每个人拿到的派最大是多少?每个派都是一个高为 ,半径不等的圆柱体。

【输入描述】

第一行包含两个正整数 nN 和m F,表示派的数量和朋友的数量。(N>=1, F<=10000)

第二行包含 N 个 1 到 10000 n之间的整数,表示每个派的半径

【输出描述】

输出每个人能得到的最大的派的体积,精确到小数点后三位。

【样例输入】

3 3 

4 3 3



【样例输出】

25.133

【题目分析】

  • 比较标准的二分

  • 注意题目中的第一个坑,N个不同的派,要分给F+1个人(因为包含自己)

  • 精确到小数点后三位,说明左右区间的判断不再是整数,需要参考上一道题 切割绳子 的写法。

  • 由原来的 直线改成圆柱体了,题目中求圆柱的体积的方法需要记住。

  • 圆周率在此题中不能取3.14。因为题目要求保留3位小数,所以要么取3.1415926。要么用  acos(-1.0)来表示圆周率



【思路】

读入所有派的半径,这个过程中求出最大的体积作为max。然后开始 二分,用mid 来分蛋糕,按照分成的数量来决定区间端点。


【参考答案】

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<iomanip>
#include<cmath>
using namespace std;
const double pi=acos(-1.0);// acos(-1.0)就是求-1.0的反余弦,经计算,acos(-1.0) 的值就是圆周率
//const double pi=3.1415926; //也可以这样定义
const int MAXX=100009;
double a[MAXX];
bool ok(double);
int n,f;
int main() {
	int T;
	double maxx=0;
	scanf("%d%d",&n,&f);
	for(int i=0; i<n; i++) {
		int r;
		scanf("%d",&r);
		a[i]=pi*r*r;//每个派的面积
		maxx=max(maxx,a[i]);//找到这里面的最大值作为右端点
	}
	double l=0,r=maxx;
	while(r-l>1e-5) { //精确 二分答案的套路过程
		double m=(l+r)/2;
		if(solve(m))
			l=m;//扩大范围,看看每个人能不能分到更多
		else
			r=m;
	}
	printf("%.3lf",l);//printf格式化输出会自动四舍五入;
	return 0;
}
bool solve(double s) { //每人是否能分面积s的派
	int sum=0;
	for(int i=0; i<n; i++) {
		sum+=floor(a[i]/s);//向下取整,分不到s的浪费;
	}
	return sum>=f+1;//能否分到
}






    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    文具订购(NOI online入门组)

    【题目描述】小明的班上共有n元班费,同学们准备使用班费集体购买3种物品。圆规,每个7元。笔,每支4元。笔记本,每本3元。小明负责订购文具,设圆规、笔、笔记本的订购数量为a,b,c,他订购的原则依次如下...

    剪刀石头布

    【题目描述】石头剪子布,是一种猜拳游戏。起源于中国,然后传到日本、朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界。简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比拼...

    【题解】电缆线(2019青岛市程序设计竞赛)

    【问题描述】在郊区有N座通信基站,P条双向电缆,第 i 条电缆连接基站 A_i 和 B_i。特别地,1号基站是通信公司的总站,N号基站位于一座农场中。现在,农场主希望对通信线路进行升级,其中升级第 i...

    【题解】放苹果(1)

    【题目描述】把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法。【输入】第一行是测试数据的数目t(0≤t≤20)。以下...

    【题解】钟神赛车

    【题目描述】钟神近来编码劳累,想骑车风光一番,于是找某君骑自行车比赛。已知某君和钟神的每辆自行车的速度,钟神赢一场得50银两银子,输一场赔50银两,平局不挣也不赔。钟神可以随意安排高中低档自行车的出场...

    【题解】跳格子

    【题目描述】地面上有一排长度为n的格子1-n,每个格子上都有一个数xi,开始时你在位置0,每次你可以向前跳1-2格,然后取走格子上的数,直到跳到位置n+1。取走的数的和就是你的得分,现在你想知道你可能...