袋中球的最小数量
1760。袋子中球的最小数量
难度:中等
主题:数组,二分查找
给定一个整数数组 nums,其中第 i 个 袋包含 nums[i] 个球。您还会获得一个整数 maxOperations。
您最多可以执行以下操作 maxOperations 次:
- 取出任意一袋球,将其分成两个新袋,其中球的数量为正个。
- 例如,一袋 5 个球可以变成两袋新的 1 球和 4 球,或者两袋新的 2 球和 3 球。
你的处罚是袋中最大个球的数量。您希望将手术后的惩罚降到最低。
执行操作后返回可能的最小惩罚。
示例1:
- 输入: nums = [9], maxOperations = 2
- 输出: 3
-
说明:
- 将装有 9 个球的袋子分成尺寸为 6 和 3 的两个袋子。 [9] -> [6,3].
- 将装有 6 个球的袋子分成尺寸为 3 和 3 的两个袋子。 [6,3] -> [3,3,3].
- 球数最多的袋子有 3 个球,所以你的罚分是 3,你应该返回 3。
示例2:
- 输入: nums = [2,4,8,2], maxOperations = 4
- 输出: 2
-
说明:
- 将装有 8 个球的袋子分成尺寸为 4 和 4 的两个袋子。 [2,4,8,2] -> [2,4,4,4,2].
- 将装有 4 个球的袋子分成尺寸为 2 和 2 的两个袋子。 [2,4,4,4,2] -> [2,2,2,4,4,2].
- 将装有 4 个球的袋子分成尺寸为 2 和 2 的两个袋子。 [2,2,2,4,4,2] -> [2,2,2,2,2,4,2].
- 将装有 4 个球的袋子分成尺寸为 2 和 2 的两个袋子。 [2,2,2,2,2,4,2] -> [2,2,2,2,2,2,2,2].
- 球数最多的袋子有 2 个球,所以你的罚分是 2,你应该返回 2。
约束:
- 1 5
- 1 9
提示:
- 如果我们知道袋子的最大尺寸,那么我们可以改变问题,你可以制作的袋子的最小数量是多少
- 请注意,随着最大尺寸的增加,最小袋子数量会减少,因此我们可以对最大尺寸进行二分搜索
解决方案:
我们可以使用二分搜索来找到可能的最小惩罚。关键的见解是,如果我们可以确定给定的惩罚是否可以实现,我们可以使用二分搜索缩小搜索范围。
解决步骤:
-
二分搜索设置:
- 最低罚分为1(所有球均分入单球袋)。
- 最大惩罚是nums数组中最大的数字。
-
可行性检查:
- 对于给定的惩罚中值,检查是否可以通过最多 maxOperations 次分割来实现它。
- 为此,对于每个袋子尺寸(以 nums 为单位),计算使所有袋子具有中间球或更少的球所需的分割数。如果总 split 超过 maxOperations,则惩罚 mid 不可行。
-
迭代:
- 根据惩罚中值是否可行,使用二分搜索调整范围[低,高]。
让我们用 PHP 实现这个解决方案:1760。袋中球的最低数量
<?php /** * @param Integer[] $nums * @param Integer $maxOperations * @return Integer */ function minimumSize($nums, $maxOperations) { ... ... ... /** * go to ./solution.php */ } /** * Helper function to check if a penalty is feasible * * @param $nums * @param $maxOperations * @param $penalty * @return bool */ function canAchievePenalty($nums, $maxOperations, $penalty) { ... ... ... /** * go to ./solution.php */ } // Example 1 $nums = [9]; $maxOperations = 2; echo minimumSize($nums, $maxOperations); // Output: 3 // Example 2 $nums = [2, 4, 8, 2]; $maxOperations = 4; echo minimumSize($nums, $maxOperations); // Output: 2 ?>
解释:
-
二分查找:
- 搜索空间介于 1 和 nums 数组中的最大数字之间。
- 中点mid代表我们当前测试的惩罚。
-
可行性检查(可以实现惩罚):
- 对于每个袋子,计算所需的分割数,以确保所有袋子的中球或更少:
- ceil(balls / mid) - 1 给出所需的分割数。
- 如果总 split 超过 maxOperations,则惩罚不可行。
- 对于每个袋子,计算所需的分割数,以确保所有袋子的中球或更少:
-
调整搜索空间:
- 如果惩罚可行,则降低上限(高=中)。
- 如果不是,则增加下限(低 = 中 1)。
-
结果:
- 当循环退出时,low包含最小的可行惩罚。
复杂:
-
时间复杂度:O(n .log(max(nums)))
- 二分搜索的运行时间为O(log(max(nums))),每个中点的可行性检查需要O(n).
- 空间复杂度:O(1),因为我们只使用恒定的额外空间。
联系链接
如果您发现本系列有帮助,请考虑在 GitHub 上给 存储库 一个星号或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!
如果您想要更多类似的有用内容,请随时关注我:
- 领英
- GitHub
以上是袋中球的最小数量的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在PHP中,应使用password_hash和password_verify函数实现安全的密码哈希处理,不应使用MD5或SHA1。1)password_hash生成包含盐值的哈希,增强安全性。2)password_verify验证密码,通过比较哈希值确保安全。3)MD5和SHA1易受攻击且缺乏盐值,不适合现代密码安全。

PHP和Python各有优势,选择依据项目需求。1.PHP适合web开发,尤其快速开发和维护网站。2.Python适用于数据科学、机器学习和人工智能,语法简洁,适合初学者。

PHP在电子商务、内容管理系统和API开发中广泛应用。1)电子商务:用于购物车功能和支付处理。2)内容管理系统:用于动态内容生成和用户管理。3)API开发:用于RESTfulAPI开发和API安全性。通过性能优化和最佳实践,PHP应用的效率和可维护性得以提升。

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。

PHP仍然具有活力,其在现代编程领域中依然占据重要地位。1)PHP的简单易学和强大社区支持使其在Web开发中广泛应用;2)其灵活性和稳定性使其在处理Web表单、数据库操作和文件处理等方面表现出色;3)PHP不断进化和优化,适用于初学者和经验丰富的开发者。

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP和Python各有优劣,选择取决于项目需求和个人偏好。1.PHP适合快速开发和维护大型Web应用。2.Python在数据科学和机器学习领域占据主导地位。

在PHP中使用预处理语句和PDO可以有效防范SQL注入攻击。1)使用PDO连接数据库并设置错误模式。2)通过prepare方法创建预处理语句,使用占位符和execute方法传递数据。3)处理查询结果并确保代码的安全性和性能。
