百练 1064 网线主管

在一场程序设计区域赛中,裁判委员会计划采用星形拓扑结构连接选手电脑,为确保公平,需将电脑等距放置。网络解决方案提供商被要求提供等长网线,但所需长度未知。本文介绍了一个算法,帮助确定最长的网线长度,以满足指定数量的等长网线需求。
描述

仙境的居民们决定举办一场程序设计区域赛。裁判委员会完全由自愿组成,他们承诺要组织一次史上最公正的比赛。他们决定将选手的电脑用星形拓扑结构连接在一起,即将它们全部连到一个单一的中心服务器。为了组织这个完全公正的比赛,裁判委员会主席提出要将所有选手的电脑等距离地围绕在服务器周围放置。

为购买网线,裁判委员会联系了当地的一个网络解决方案提供商,要求能够提供一定数量的等长网线。裁判委员会希望网线越长越好,这样选手们之间的距离可以尽可能远一些。

该公司的网线主管承接了这个任务。他知道库存中每条网线的长度(精确到厘米),并且只要告诉他所需的网线长度(精确到厘米),他都能够完成对网线的切割工作。但是,这次,所需的网线长度并不知道,这让网线主管不知所措。

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

输入

第一行包含两个整数N和K,以单个空格隔开。N(1 <= N <= 10000)是库存中的网线数,K(1 <= K <= 10000)是需要的网线数量。
接下来N行,每行一个数,为库存中每条网线的长度(单位:米)。所有网线的长度至少1m,至多100km。输入中的所有长度都精确到厘米,即保留到小数点后两位。

输出

网线主管能够从库存的网线中切出指定数量的网线的最长长度(单位:米)。必须精确到厘米,即保留到小数点后两位。
若无法得到长度至少为1cm的指定数量的网线,则必须输出“0.00”(不包含引号)。

样例输入
4 11
8.02
7.43
4.57
5.39
样例输出
2.00
m, n = map(int, input().split())
s = []
max_len = 0
for i in range(0, m):
    s.append(int(float(input()) * 100))
    if max_len < s[i]:
        max_len = s[i]

# 网线长度的取值范围
l = 0
r = max_len + 1

while r - l > 1:
    w = 0
    mid = (l + r) // 2  # 必须是整除,否则WA
    for i in range(m):
        w += s[i] // mid
    if w >= n:  # 得到的网线数多了
        l = mid  # 增加网线长度
    else:  # 得到的网线数少了
        r = mid  # 减少网线长度

l = format(l / 100, ".2f")
print(l)
### 网线管理中的二分查找算法应用场景 在网络环境中,尽管默认网关可以用于网络管理和监控[^1],但在具体的物理层面上,如大量网线的管理上,二分查找算法同样有着独特的应用价值。当面对大量的网线连接时,尤其是数据中心或大型企业内部复杂的布线环境,快速定位特定端口或者识别某根网线对应的设备成为了一项挑战。 #### 应用场景描述 对于有序排列并标记好的交换机端口号或是配线架上的编号而言,如果这些编号按照一定顺序排列,则可利用二分查找法迅速找到指定ID所关联的具体位置。这不仅提高了工作效率,还减少了人工排查可能带来的错误率。 #### 实现方法概述 为了在网线管理系统中实施有效的二分查找策略: - **预处理阶段**:确保所有网线及其终端均已按某种逻辑规则(比如从小到大)进行了唯一性的编号,并将其存入数据库或其他形式的数据结构中。 - **查询过程**: - 定义待查目标值`target`; - 设定初始边界条件,左指针指向数组起始处(`low=0`),右指针指向结束位置(`high=length-1`); - 进行循环比较直至找到匹配项或确认不存在该条目;每次迭代通过中间索引`(mid=(low+high)/2)`获取当前考察对象并与`target`对比大小关系调整新的搜索区间范围直到满足终止条件为止。 ```python def binary_search(wire_ids, target): low = 0 high = len(wire_ids) - 1 while low <= high: mid = (low + high) // 2 if wire_ids[mid]['id'] == target: return wire_ids[mid] elif wire_ids[mid]['id'] < target: low = mid + 1 else: high = mid - 1 return None ``` 此函数接收两个参数:一个是已经排序过的网线列表`wire_ids`,其中每个元素都是字典类型表示单个网线的信息;另一个是要寻找的目标ID `target`. 函数返回的是与给定ID相匹配的那个网线详情或者是None表明未发现对应记录。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值