2551. Put Marbles in Bags
Description
You have k
bags. You are given a 0-indexed integer array weights
where weights[i]
is the weight of the i^th
marble. You are also given the integer k.
Divide the marbles into the k
bags according to the following rules:
- No bag is empty.
- If the
i^th
marble andj^th
marble are in a bag, then all marbles with an index between thei^th
andj^th
indices should also be in that same bag. - If a bag consists of all the marbles with an index from
i
toj
inclusively, then the cost of the bag isweights[i] + weights[j]
.
The score after distributing the marbles is the sum of the costs of all the k
bags.
Return the difference between the maximum and minimum scores among marble distributions.
Example 1:
1 | Input: weights = [1,3,5,1], k = 2 |
Example 2:
1 | Input: weights = [1, 3], k = 2 |
Constraints:
1 <= k <= weights.length <= 10^5
1 <= weights[i] <= 10^9
Hints/Notes
- 2025/04/06 Q3
- sorting
- 0x3Fâs solution
Solution
Language: C++
1 | class Solution { |