博客
关于我
2019ICPC 沈阳重现 L-Flowers(二分)
阅读量:390 次
发布时间:2019-03-05

本文共 742 字,大约阅读时间需要 2 分钟。

Jack想要为爱人准备若干鲜花束,每个花束必须包含M朵不同物种的花。花店有N种花,第i种的花有a_i朵。Jack想知道最多能准备多少个花束。

解决这个问题,可以使用二分查找法。对于一个给定的x(假设x是花束的数量),我们需要检查是否能满足至少x个花束,每个花束有M朵花,且每种花的使用数量不超过其可用数量。

具体步骤如下:

  • 输入处理:读取输入数据,获取测试用例的数量T。对于每个测试用例,读取N、M,然后读取a数组。

  • 初始检查:计算所有花的总数sum_a。如果sum_a < M,无法组成一个花束,直接返回0。

  • 二分查找:设置low=0,high=sum_a / M。进行二分查找,找到最大的x使得sum(min(a_i, x)) >= x*M。

  • 检查函数:对于每个mid值,计算sum(min(a_i, mid)),判断是否满足条件。如果满足,说明x可以更大,调整low=mid+1;否则,调整high=mid-1。

  • 通过这种方法,可以高效地确定最多能准备的花束数量。


    答案:

    使用二分查找法来确定最多能准备的花束数量。具体步骤如下:

  • 输入处理:读取输入数据,获取测试用例的数量T。对于每个测试用例,读取N、M,然后读取a数组。

  • 初始检查:计算所有花的总数sum_a。如果sum_a < M,无法组成一个花束,直接返回0。

  • 二分查找:设置low=0,high=sum_a / M。进行二分查找,找到最大的x使得sum(min(a_i, x)) >= x*M。

  • 检查函数:对于每个mid值,计算sum(min(a_i, mid)),判断是否满足条件。如果满足,说明x可以更大,调整low=mid+1;否则,调整high=mid-1。

  • 通过这种方法,可以高效地确定最多能准备的花束数量。

    转载地址:http://thewz.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现精准计时(附完整源码)
    查看>>
    Objective-C实现系统时间戳(附完整源码)
    查看>>
    Objective-C实现累加校验和(附完整源码)
    查看>>
    Objective-C实现红黑树算法(附完整源码)
    查看>>
    Objective-C实现约分(化简比)(附完整源码)
    查看>>
    Objective-C实现约瑟夫环算法(附完整源码)
    查看>>
    Objective-C实现线性反馈移位寄存器LFSR(附完整源码)
    查看>>
    Objective-C实现线性查找算法(附完整源码)
    查看>>
    Objective-C实现线程池(附完整源码)
    查看>>
    Objective-C实现组合模式(附完整源码)
    查看>>
    Objective-C实现绘制跳动的桃心(附完整源码)
    查看>>
    Objective-C实现给定一个 NxN 网格,找出单元格 [0, 0] 中的老鼠是否可以到达单元格 [N-1, N-1] 中的目标算法(附完整源码)
    查看>>
    Objective-C实现给定一个句子,返回出现次数最多的单词算法(附完整源码)
    查看>>
    Objective-C实现给定一个数字数组,返回最大乘积数组中的 3 个数字算法(附完整源码)
    查看>>
    Objective-C实现给定一个整数 n,将最小步数返回到 1算法(附完整源码)
    查看>>
    Objective-C实现给定一串字符,返回出现频率最高的字符算法(附完整源码)
    查看>>
    Objective-C实现给定两个数字 n 和 k,使 k 数字的所有唯一组合从 1 到 n 并按排序顺序算法(附完整源码)
    查看>>
    Objective-C实现给定两个长度相同的字符串s1和s2,如果s2是s1的乱序字符串则返回真,否则返回假算法(附完整源码)
    查看>>
    Objective-C实现给定分隔符加入字符串列表算法(附完整源码)
    查看>>
    Objective-C实现给某个文件或文件夹赋予特定访问权限(附完整源码)
    查看>>