新校区布网

描述

童程学校建立新校区,需要部署网线。学校联系了当地的一个网络解决方案提供商,要求能够提供一定数量的等长网线。学校希望网线越长越好,这样选手们之间的距离可以尽可能远一些。

该公司承接了这个任务。他们知道库存中每条网线的长度(精确到厘米,是指网线长度小数点后最多只有两位数,没有第 3 位),并且只要告诉他所需的网线长度(精确到厘米,是指网线长度小数点后最多只有两位数,没有第 3 位),他们都能够完成对网线的切割工作。但是,这次,所需的网线长度并不知道,这让该公司不知所措。

你需要编写一个程序,帮助该公司确定一个最长的网线长度,并且按此长度对库存中的网线进行切割,能够得到指定数量的网线。

输入描述

第一行包含两个整数 N 和 K,以单个空格隔开。N (1≤N≤10000)是库存中的网线数,K(1≤K≤10000)是需要的网线数量。

接下来 N 行,每行一个数,为库存中每条网线的长度(单位:米)。所有网线的长度至少 1cm,至多 100km。输入中的所有长度都精确到厘米,小数点后只有两位数,即保留到小数点后两位。

输出描述

该公司能够从库存的网线中切出指定数量的网线的最长长度(单位:米)。必须精确到厘米,即保留到小数点后两位。

若无法得到长度至少为 1cm 的指定数量的网线,则必须输出" 0.00 "(不包含引号)。

样例输入 1

复制代码
4 11
8.02
7.43
4.57
5.39

样例输出 1

复制代码
2.00

提示

数据范围与提示:

1≤N≤10000,1≤K≤10000

代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n,k,a[100001],r,l,ans,mid;
double x;
bool c(int mid){
	int s=0;
	for(int i=1;i<=n;i++){
		s+=a[i]/mid;
	}
	return s>=k;
}
int main(){
	cin>>n>>k;
	for(int i=1;i<=n;i++){
		cin>>x;
		a[i]=x*100;
		r=max(r,a[i]);
	}
	while(l<=r){
		mid=(l+r)/2;
		if(c(mid)){
			ans=mid;
			l=mid+1;
		}else{
			r=mid-1;
		}
	}
	printf("%.2lf",ans/100.0);
	return 0;
}

以上内容均为原创;欢迎参考、借鉴!

但拒绝盗版;也禁止任何人在未经本人同意的条件下用于商业用途。

作者保留法律追究责任。

相关推荐
人工智能AI技术4 分钟前
GitHub Copilot 2026新功能实操:C++跨文件上下文感知开发,效率翻倍技巧
c++·人工智能
大志若愚YYZ34 分钟前
ROS2学习 C++中的this指针
c++·学习·算法
玖釉-1 小时前
[Vulkan 学习之路] 16 - 最终章:渲染循环与同步 (Rendering & Presentation)
c++·windows·图形渲染
狗狗学不会1 小时前
Pybind11 封装 RK3588 全流程服务:Python 写逻辑,C++ 跑并发,性能起飞!
c++·人工智能·python·目标检测
DYS_房东的猫1 小时前
《 C++ 零基础入门教程》第10章:C++20 核心特性 —— 编写更现代、更优雅的 C++
java·c++·c++20
Howrun7772 小时前
虚幻引擎_AController_APlayerController_AAIController
开发语言·c++·游戏引擎·虚幻
小林rr2 小时前
深入探索 C++:现代特性、工程实践与性能优化全解
java·c++·性能优化
羊小猪~~2 小时前
【QT】-- QT基础类
开发语言·c++·后端·stm32·单片机·qt
努力写代码的熊大3 小时前
深入探索C++关联容器:Set、Map、Multiset与Multimap的终极指南及底层实现剖析
开发语言·c++
txinyu的博客3 小时前
Linux 内存管理
linux·运维·开发语言·c++