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<iostream> #include<cstring> #include<algorithm> #include<cstdio> #include<queue> #include<math.h> using namespace std; int n,k; long long a[21900]; long long l,r,mid; double ans; long long check(long long x) { long long sum=0; for(int i=1;i<=n;i++) sum+=a[i]/x; return sum; } int main() { scanf("%d%d",&n,&k); double t; for(int i=1;i<=n;i++) { scanf("%lf",&t);t*=100; a[i]=(long long )t; } l=0;r=9999999899; while(l<=r) { mid=(l+r+1)>>1; if (l==r) break; if(check(mid)>=k) l=mid; else r=mid-1; } ans=mid*1.00/100; printf("%.2lf",ans); return 0; }
#include<iostream> #include<cstring> #include<algorithm> #include<cstdio> #include<queue> #include<math.h> using namespace std; int n,k; long long a[11000]; long long l,r,mid; int check(int x) { int sum=0; for(int i=1;i<=n;i++) sum+=a[i]/x; return sum; } int main() { scanf("%d%d",&n,&k); double t; for(int i=1;i<=n;i++) { scanf("%lf",&t);t*=100; a[i]=(int)t,r+=a[i]; } l=1;r+=1; while(l<=r) { mid=(l+r)>>1; if(check(mid)>=k) l=mid+1; else r=mid-1; } printf("%.2lf",(double)(r*1.0/100)); return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App