Smash The Bricks(NG)
There are n bricks arranged in a row at positions numbered
from 1 through n, inclusive. There is an array, newtons[n], that
contains an integer indicating the number of newtons required to
smash a brick. (A newton is a unit of force.)
There are two hammers, one big and one small. The big hammer
can smash any brick with one blow. The small hammer reduces the
newtons required by 1 for each blow to a brick. For example, a brick
requires 3 newtons of force. It will take 1 blow with the big hammer,
or 3 blows with the small hammer to smash it. There is a limit to
how many times the big hammer can be used.
Determine 3 values:
Return the values as a 2-dimensional integer array, [[total hits], [big hammer hits], [small hammer hits]]. If a hammer is not used, its index array should be [-1].
Complete the function smashTheBricks in the editor below.
smashTheBricks has the following parameters:
int bigHits: the maximum blows with the big hammerint newtons[n]: the newtons required to smash each brick
Returns
long [][], [p][q]: in the form [[ total hits], [sorted indices for big hammer hits], [sorted indices for small hammer hits]]
1Example 1
2 blows to smash the single brick at index 1. The return array is [[2], [-1], [1]].2Example 2
[3, 5, 7], using 4 hits to smash them all. The small hammer is used on sorted indices [1, 2, 4], which have newtons of 3, 2, and 4. It takes a total of 3 + 2 + 4 = 9 hits with the small hammer. The total blows required = 4 + 9 = 13. The return array is [[13], [3, 5, 6, 7], [1, 2, 4]].3Example 3
4Example 4
Constraints
Limits and guarantees your solution can rely on.
1 ≤ n ≤ 2 x 1050 ≤ bigHits ≤ 2 x 1051 ≤ newtons[i] ≤ 109newtons[] are distinct.