【二分\搜索\剪枝】软件下载

本文介绍了如何在有限的电脑资源下,通过优化软件下载顺序,利用二分搜索和剪枝策略,以最短时间完成多个软件的下载任务。问题背景为ICG大赛的准备工作,探讨了错误的N^M方法与正确的M!搜索方法,并强调了在软件大小排序基础上的剪枝技巧对提高效率的重要性。

3、软件下载

ICG大赛马上就要举行了,作为大赛的组委会兼参赛选手,信息组的成员们当然要做准备了,而其中十分重要的一项准备工作就是下载很多举办大赛必不可少的软件,已知现在机房有N台电脑,组委会列出了M个需要下载的软件及其大小Ai(即需要下载的时间),每个电脑同一时间只能下载一个软件,一个软件也只能由一个电脑下载,每个电脑下载速度相同且互不影响.因为有神器Cena的存在,每个软件只需由某一台电脑下载一次就能使整个机房的电脑普及该软件。现在ICG组委会想知道最快能在多长时间内下载完成。

输入格式

第1行:两个整数N、M,分别代表机房的电脑数及需要下载的软件数量。

第2行:M个整数,第i个整数表示Ai的值。

输出格式

一行一个整数,表示能下载完所有软件的最短时间。

输入样例:

2 3

1 2 3

输出样例

3

 

数据范围:

1<=n<=10

1<=m<=50



这道题比较好。因为考察了剪枝的技巧。


讨论二分的检验:

我一开始想的方法是N^M的方法,但是错误算成了M!/N!,所以导致我用了低效的方法。

正确的方法应该是M!的搜索,即先从大到小排序,依次把每一个软件分配给计算机。如果说分配不了了,那么,就分配到下一个计算机。否则可以选择分配给当前计算机,或者暂时不,转而判断下一个软件。

这样做仍然过不了。但是考虑而我们事先排了序,越到后面越小,假设我们以最优情况考虑,让每台电脑都以刚好以二分出的最短时间下载完,如果说这样都还不能下载完剩余的软件,则剪枝。这样就能秒过了。


关键是在于“越到后面时间长短越小”。。


#include <c
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值