P1297 网线切割
2024-09-02 10:27:24
P1297 网线切割
题目描述
Wonderland居民决定举行一届地区性程序设计大赛。仲裁委员会志愿负责这次赛事并且保证会组织一次有史以来最公正的比赛。为此,所有参赛者的电脑和网络中心会以星状网络连接,也就是说,对每个参赛者,组委会会用一根长度一定的网线将他的计算机与中心连接,使得他们到网络中心的距离相等。
为了买网线,组委会与当地的网络公司联系,要向他们购买一定数目的等长网线,这些网线要尽可能的长,使得组织者可以让选手们彼此远离。
于是公司指派管理网线事务的负责人解决此事。负责人清楚地知道仓库里每根网线的长度(精确到厘米:cm),他也可以将他们以厘米的精度切割——前提是他得知道切成多长。但是现在,这个长度他算不出来,于是他彻底迷茫了。
你要做的,就是帮助困惑的负责人。编一个程序求出为了得到一定数目的等长网线,每根网线最大的可能长度。
输入输出格式
输入格式:
输入文件的第一行由两个整数N和K组成,由一个空格间隔。N(1≤N≤10000)是仓库里光缆的数目,K(1≤K≤10000)是需要的网线数目。
接下来的N行每行只有一个实数,告诉你每根缆线的长度(单位:m)。这些网线至少长1m,最多不超过100km。
所有的长度精确到cm,且小数点后有且仅有两位。
输出格式:
把你求得的最大网线长度写进输出文件(单位:m)。长度要精确到cm,并且输出时小数点后要恰有两位。
如果无论如何也不可能切割出需要数目的网线(每根至少1cm长),那么就输出“0.00”(不包括引号)。
输入输出样例
输入样例#1:
4 11
8.02
7.43
4.57
5.39
输出样例#1:
2.00
#include<cstdio>
#include<cmath> double a[];
int n,k;
bool check(double x)
{
int sum = ;
for (int i=; i<=n; ++i)
{
sum += (int)(a[i]/x);
if (sum>=k) return true ;
}
return false ;
}
int main()
{
scanf("%d%d",&n,&k);
for (int i=; i<=n; ++i)
scanf("%lf",&a[i]);
double l = 0.0, r = 1000000.0;
for (int i=; i<=; ++i)
{
double mid = (l+r)/;
if (check(mid)) l = mid;
else r = mid;
}
printf("%.2lf",floor(r*)/);
return ;
}
最新文章
- MFC中成员变量的声明顺序与析构顺序
- window下安装jupyter
- Oracle--用变量保存查询出来的值
- .net下各个数据类型所占用的字节
- 【crunch bang】 增加“菜单项”
- jQuery插件开发 格式与解析3之$.extend()用途
- linux之sed命令
- MySQL存储过程--带参数报错1064
- poj3237 树链部分 边权模板
- 【jq】prop和attr的区别
- 初学python之路-day01
- Python Tkinter 简单使用
- ATR102E Stop. Otherwise... [容斥]
- Select2 多层次赋值时异步赋值的问题
- java8中的时间处理
- input.php
- 【ARC082E】ConvexScore
- LeetCode All in One题解汇总(持续更新中...)
- Spring 父子容器
- MyBatis—动态SQL
热门文章
- python-rrdtool
- System Center Configuration Manager 2016 必要条件准备篇(Part3)
- 05、Spark
- Spring MVC框架下提交Date数据无法在controller直接接收
- 转:postMan 使用教程
- VERITA Netbackup日常巡检详细说明
- node.js 下使用 util.inherits 来实现继承
- 2018.8.4session的removeAttribute()和invalidate()的区别
- jquery操作DOM 元素(2)
- 通过tomcat配置访问本机资源