1710. 卡车上的最大单元数
1710. 卡车上的最大单元数
题目
You are assigned to put some amount of boxes onto one truck. You are given a 2D array boxTypes
, where boxTypes[i] = [numberOfBoxesi, numberOfUnitsPerBoxi]
:
numberOfBoxesi
is the number of boxes of typei
.numberOfUnitsPerBoxi
is the number of units in each box of the typei
.
You are also given an integer truckSize
, which is the maximum number of boxes that can be put on the truck. You can choose any boxes to put on the truck as long as the number of boxes does not exceed truckSize
.
Return the maximum total number of units that can be put on the truck.
Example 1:
Input: boxTypes = [[1,3],[2,2],[3,1]], truckSize = 4
Output: 8
Explanation: There are:
- 1 box of the first type that contains 3 units.
- 2 boxes of the second type that contain 2 units each.
- 3 boxes of the third type that contain 1 unit each.
You can take all the boxes of the first and second types, and one box of the third type.
The total number of units will be =
(1 * 3) + (2 * 2) + (1 * 1) = 8
.
Example 2:
Input: boxTypes = [[5,10],[2,5],[4,7],[3,9]], truckSize = 10
Output: 91
Constraints:
1 <= boxTypes.length <= 1000
1 <= numberOfBoxesi, numberOfUnitsPerBoxi <= 1000
1 <= truckSize <= 10^6
题目大意
请你将一些箱子装在 一辆卡车 上。给你一个二维数组 boxTypes
,其中 boxTypes[i] = [numberOfBoxesi, numberOfUnitsPerBoxi]
:
numberOfBoxesi
是类型i
的箱子的数量。numberOfUnitsPerBoxi
是类型i
每个箱子可以装载的单元数量。
整数 truckSize
表示卡车上可以装载 箱子 的 最大数量 。只要箱子数量不超过 truckSize
,你就可以选择任意箱子装到卡车上。
返回卡车可以装载 单元 的 最大 总数。
示例 1:
输入: boxTypes = [[1,3],[2,2],[3,1]], truckSize = 4
输出: 8
解释: 箱子的情况如下:
- 1 个第一类的箱子,里面含 3 个单元。
- 2 个第二类的箱子,每个里面含 2 个单元。
- 3 个第三类的箱子,每个里面含 1 个单元。
可以选择第一类和第二类的所有箱子,以及第三类的一个箱子。
单元总数 =
(1 * 3) + (2 * 2) + (1 * 1) = 8
示例 2:
输入: boxTypes = [[5,10],[2,5],[4,7],[3,9]], truckSize = 10
输出: 91
提示:
1 <= boxTypes.length <= 1000
1 <= numberOfBoxesi, numberOfUnitsPerBoxi <= 1000
1 <= truckSize <= 10^6
解题思路
可以通过贪心算法解决。
优先选择单位数多的箱子:
- 将
boxTypes
按单位数降序排列。 - 优先装载单位数最多的箱子,这样每装载一部分,能获得最大的单位数。
- 将
装载逻辑:
- 对于每种箱子类型,取卡车剩余容量和当前箱子数量的最小值作为装载数量。
- 更新卡车剩余容量,并累加单位数。
终止条件:
- 如果卡车已满(
truckSize == 0
),可以提前终止遍历。 - 返回总装载数量
- 如果卡车已满(
复杂度分析
- 时间复杂度:
O(n log n)
- 排序时间:
O(n log n)
,其中n
为boxTypes
的长度。 - 遍历
boxTypes
:O(n)
。 - 总复杂度:
O(n log n)
。
- 排序时间:
- 空间复杂度:
O(1)
,只用了常数额外空间。
代码
/**
* @param {number[][]} boxTypes
* @param {number} truckSize
* @return {number}
*/
var maximumUnits = function (boxTypes, truckSize) {
// 按单位数降序排序
boxTypes.sort((a, b) => b[1] - a[1]);
let res = 0;
for (let [num, unit] of boxTypes) {
if (truckSize == 0) break; // 卡车满了则终止
// 装载的箱子数量
const boxes = Math.min(truckSize, num);
res += boxes * unit; // 累加单位数
truckSize -= boxes; // 更新剩余容量
}
return res;
};
相关题目
题号 | 标题 | 题解 | 标签 | 难度 | 力扣 |
---|---|---|---|---|---|
2279 | 装满石头的背包的最大数量 | 贪心 数组 排序 | 🟠 | 🀄️ 🔗 |