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^thmarble andj^thmarble are in a bag, then all marbles with an index between thei^thandj^thindices should also be in that same bag. - If a bag consists of all the marbles with an index from
itojinclusively, 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^51 <= weights[i] <= 10^9
Hints/Notes
- 2025/04/06 Q3
- sorting
- 0x3Fâs solution
Solution
Language: C++
1 | class Solution { |