LeetCode in Kotlin

1710. Maximum Units on a Truck

Easy

You are assigned to put some amount of boxes onto one truck. You are given a 2D array boxTypes, where boxTypes[i] = [numberOfBoxesi, numberOfUnitsPerBoxi]:

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:

Example 2:

Input: boxTypes = [[5,10],[2,5],[4,7],[3,9]], truckSize = 10

Output: 91

Constraints:

Solution

@Suppress("NAME_SHADOWING")
class Solution {
    fun maximumUnits(boxTypes: Array<IntArray>, truckSize: Int): Int {
        var truckSize = truckSize
        boxTypes.sortWith { b1: IntArray, b2: IntArray -> Integer.compare(b2[1], b1[1]) }
        var maxUnits = 0
        var i = 0
        while (truckSize > 0 && i < boxTypes.size) {
            if (boxTypes[i][0] <= truckSize) {
                maxUnits += boxTypes[i][0] * boxTypes[i][1]
                truckSize -= boxTypes[i][0]
            } else {
                maxUnits += Math.min(truckSize, boxTypes[i][0]) * boxTypes[i][1]
                truckSize -= Math.min(truckSize, boxTypes[i][0])
            }
            i++
        }
        return maxUnits
    }
}