forked from haoel/leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMaximumUnitsOnATruck.cpp
69 lines (67 loc) · 2.45 KB
/
MaximumUnitsOnATruck.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Source : https://leetcode.com/problems/maximum-units-on-a-truck/
// Author : Hao Chen
// Date : 2021-03-30
/*****************************************************************************************************
*
* 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 type i.
* numberOfUnitsPerBoxi is the number of units in each box of the type i.
*
* 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
******************************************************************************************************/
class Solution {
private:
void print(vector<vector<int>>& boxes) {
cout << "{ ";
for(int i=0; i<boxes.size()-1; i++){
cout << "[" << boxes[i][0] << ","<< boxes[i][1] << "], ";
}
int i=boxes.size()-1;
cout << "[" << boxes[i][0] << ", "<< boxes[i][1] << "] } "<< endl;
}
public:
int maximumUnits(vector<vector<int>>& boxTypes, int truckSize) {
sort(boxTypes.begin(), boxTypes.end(),
[&](vector<int>& lhs, vector<int>& rhs){return lhs[1] > rhs[1]; });
//print(boxTypes);
int units = 0;
for(auto& box : boxTypes) {
if (truckSize >= box[0]) {
units += box[0] * box[1];
}else{
units += truckSize * box[1];
}
truckSize -= box[0];
if (truckSize <= 0 ) break;
}
return units;
}
};