ACM pie
我的朋友们很烦人,如果他们中的一个比其他人得到更大的一块,他们就会开始抱怨。因此,他们所有人都应该得到同样大小(但不一定是同样的形状)的碎片,即使这导致了一些馅饼被破坏(这比破坏聚会更好)。 当然,我也想要一块馅饼,那块也应该是同样大小的。
我们所有人都可以获得最大的可能尺寸是多少?所有的馅饼都是圆柱形的,它们都具有相同的高度1,但馅饼的半径可能不同的。
Input
一行为正整数:测试用例数。 然后对于每个测试用例:
---一行与两个整数N和F与1 <= N,F <= 10000:饼的数量和朋友的数量。
---一行N个整数ri与1 <= ri <= 10000:馅饼的半径。
Output
对于每个测试用例,输出一行,最大可能体积V,这样我和我的朋友们都能得到一块馅饼的大小,答案应该是作为一个浮点数而且绝对误差最多10 ^(-3)。
Sample Input
3
3 3
4 3 3
1 24
5
10 5
1 4 2 3 4 5 6 5 4 2
Sample Output25.1327
3.1416
50.2655 就是我要开party了,朋友来了,我要均分n块馅饼给自己和朋友们,但是呢,每个人只能得到一块馅饼,不能有拼接的馅饼块。
按道理 人数应该为f+1了,
想一想,一种馅饼可能分给好几人食用,我可以用二分法在0和最大馅饼块之间先求出预设的最大值 ,然后让每种馅饼除以预设的最大值,取整,得到块数,当所有的累加的块数大于总人数的时候,即该值满足题意.
#include<bits/stdc++.h>
using namespace std;
const double PI = acos(-1.0);
double pie[]; int t,n,f;/*t:次数 n:馅饼的数量 f:朋友数量,因为自己也要分馅饼,所以记得要有 f++*/
bool cmp(double a,double b)
{
return a > b;
}
int judge(double mid) /*判断预设的最大值是否满足题意*/
{
int sum = ;
for(int i = ; i < n; i++)
{
sum += int(pie[i]/mid);
if(sum >= f)
return ;
}
return ;
}
int main()
{
while(cin>>t)
{ while(t--)
{
double right,left,mid;
scanf("%d %d",&n,&f);
f++;
for(int i = ;i < n; i++)
{
scanf("%lf",&pie[i]);
pie[i] = pie[i]*pie[i]*PI; /*改为存储pie的体积,方便之后的运算*/
}
sort(pie,pie+n,cmp); /*排序完成之后 直接拿第一个来开刀*/
left = ;
right = pie[];
while(right - left > 1e-)
{
mid = (left+right)/;
if(judge(mid))
left = mid;
else
right = mid;
}
printf("%.4lf\n",mid);
}
} return ;
}
一些奇奇怪怪的事情:(其实,不是很奇怪,就是取值范围的问题)
当right-left>1e-5时,输出mid是WA 输出left反而是AC
当right-left>le-6或者1e-7时 输出mid是AC
当right - left>1e-8或者更小的时候,就OLE了
ACM pie的更多相关文章
- acm数学(转)
这个东西先放在这吧.做过的以后会用#号标示出来 1.burnside定理,polya计数法 这个大家可以看brudildi的<组合数学>,那本书的这一章写的很详细也很容易理解.最好能 ...
- 分馅饼 Pie
Pie 链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=85904#problem/C 题目: Problem Description ...
- 杭电ACM分类
杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...
- HDU-1969 Pie
http://acm.hdu.edu.cn/showproblem.php?pid=1969 Pie Time Limit: 5000/1000 MS (Java/Others) Memory ...
- 2006 ACM Northwestern European Programming Contest C题(二分求最大)
My birthday is coming up and traditionally I'm serving pie. Not just one pie, no, I have a numberN o ...
- ACM数学
1.burnside定理,polya计数法 这个专题我单独写了个小结,大家可以简单参考一下:polya 计数法,burnside定理小结 2.置换,置换的运算 置换的概念还是比较好理解的,< ...
- hdu 1969 Pie(二分查找)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1969 Pie Time Limit: 5000/1000 MS (Java/Others) Me ...
- SCNU ACM 2016新生赛决赛 解题报告
新生初赛题目.解题思路.参考代码一览 A. 拒绝虐狗 Problem Description CZJ 去排队打饭的时候看到前面有几对情侣秀恩爱,作为单身狗的 CZJ 表示很难受. 现在给出一个字符串代 ...
- SCNU ACM 2016新生赛初赛 解题报告
新生初赛题目.解题思路.参考代码一览 1001. 无聊的日常 Problem Description 两位小朋友小A和小B无聊时玩了个游戏,在限定时间内说出一排数字,那边说出的数大就赢,你的工作是帮他 ...
随机推荐
- nexus私服服务器意外关机后,本地不能下载jar包
主要记录一个小问题. 今天要做个需求,需要读取word文档中的表格来在生成数据库建表语句. 读取word文档,要添加maven依赖 <dependency> <groupId> ...
- java 中String类的常用方法总结,带你玩转String类。
String类: String类在java.lang包中,java使用String类创建一个字符串变量,字符串变量属于对象.String类对象创建后不能修改,StringBuffer & St ...
- SpringMVC(六):@RequestMapping下使用@RequestHeader绑定请求报头的属性值、@CookieValue绑定请求中的Cookie值
备注:我本地浏览器的报头(Request Header)信息如下: Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image ...
- Object.prototype.toString.call(obj)使用方法以及原理
这几天看vue-router的源码 发现了Object.prototype.toString.call()这样的用法,当时以为这就是转成字符串的用的,但是越看越觉得不太对劲,赶紧查查资料,一查才知道没 ...
- ansible+packer+terraform在aws上布署web服务器
各工具所扮演的角色 ansible: 配合packer生成安装有apache的基础镜像 packer: 生成amazon AMI terraform: 以packer生成的镜像为基础,布署web服务器 ...
- 如何用Math.max.apply()获取数组最大/小值
最近似乎对JavaScript有点兴趣了~~~打算好好钻研这个东西.可是,一开始就遇到问题了!!! Math.min.apply(obj,args);//这个obj对象将代替Function类里thi ...
- Python求解啤酒问题(携程2016笔试题)
问题描述:一位酒商共有5桶葡萄酒和1桶啤酒,6个桶的容量分别为30升.32升.36升.38升.40升和62升,并且只卖整桶酒,不零卖.第一位顾客买走了2整桶葡萄酒,第二位顾客买走的葡萄酒是第一位顾客的 ...
- Java8-Collect收集Stream
Collection, Collections, collect, Collector, Collectos Collection是Java集合的祖先接口. Collections是java.util ...
- 【LSGDOJ1836】: 量化交易 贪心
题目描述 applepi 训练了一个可以自动在股票市场进行量化交易的模型.通常来说,applepi 写出的模型,你懂得,就好比一架印钞机.不过为了谨慎起见,applepi还是想先检查一下模型的效果.a ...
- 【bzoj4008 hnoi2015】 亚瑟王
题目描述 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑.他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂亮.众所周知,亚瑟王是一个看脸的游戏,技能 ...