Given an array of integers and an integer m, in one operation, choose atmost m numbers of the array and increment them.
What is the minimum no of operations to make all the elements in the array equal?
1 <= nums[i] <= 1e5
1 <= m <= 1e5
# | User | Rating |
---|---|---|
1 | jiangly | 3976 |
2 | tourist | 3815 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3614 |
5 | orzdevinwang | 3526 |
6 | ecnerwala | 3514 |
7 | Benq | 3482 |
8 | hos.lyric | 3382 |
9 | gamegame | 3374 |
10 | heuristica | 3357 |
# | User | Contrib. |
---|---|---|
1 | cry | 170 |
2 | -is-this-fft- | 165 |
3 | Um_nik | 161 |
3 | atcoder_official | 161 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 154 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Given an array of integers and an integer m, in one operation, choose atmost m numbers of the array and increment them.
What is the minimum no of operations to make all the elements in the array equal?
1 <= nums[i] <= 1e5
1 <= m <= 1e5
Name |
---|
.
assuming the numbers are incremented by one i think you can just sort the array and the biggest value minus the smallest would be the answer
why are you people upvoting my wrong solution this solution is wrong i posted the right one in the replies grahhhhh
nevermind i realized the issue with this approach i am so terrible at this. this doesnt work if the m integer is smaller
then i think you just sort an array and then while the smallest integer is smaller than the biggest you increment the smallest integers in the array with a for loop if the array is not smaller then the loop breaks
we add 1 to the counter and sort the array at the end of a while loop as well
i have no idea how to phrase any of this better i myself am probably on the same level of coding
heres the lump of python code that I THINK works:
bro do paste the question link
https://www.hackerrank.com/contests/coderit-coding-day-january-chapter/challenges/sab-barabar
I think this works.
Yes your solution is correct. Thanks a lot!
i think u just have to sum the difference between max and every other element in the array, and then divide the sum by m, ceil(sum), to ensure that if there were remainders, it can be rounded up.