Here is a link for the problem.
I found an approach in discussion: "You have to divide the participants into equal teams (rounded)", but I cannot understand why it's correct!
| № | Пользователь | Рейтинг |
|---|---|---|
| 1 | Benq | 3792 |
| 2 | VivaciousAubergine | 3647 |
| 3 | Kevin114514 | 3611 |
| 4 | jiangly | 3583 |
| 5 | strapple | 3515 |
| 6 | tourist | 3470 |
| 7 | Radewoosh | 3415 |
| 8 | Um_nik | 3376 |
| 9 | maroonrk | 3361 |
| 10 | XVIII | 3345 |
| Страны | Города | Организации | Всё → |
| № | Пользователь | Вклад |
|---|---|---|
| 1 | Qingyu | 162 |
| 2 | adamant | 148 |
| 3 | Um_nik | 146 |
| 4 | Dominater069 | 143 |
| 5 | errorgorn | 141 |
| 6 | cry | 138 |
| 7 | Proof_by_QED | 136 |
| 8 | YuukiS | 135 |
| 9 | chromate00 | 134 |
| 10 | soullless | 133 |
| Название |
|---|



In this problem you need to divide them into M teams, so you need to find an array a[1..M] such that its sum is N and its product is maximized.
Okay, suppose there is an optimal sequence of a[] such that there are two elements with difference greater than 1. Then, product is P * X * Y (X + 1 < Y), where P is product of other elements, while X and Y are these two elements with difference greater than 1 (X + 1 < Y).
Now, let's make X++ and Y-- and see what happens. Product becomes P * (X + 1) * (Y — 1) = P * X * Y + P * Y — P * X — P = P * X * Y + P * (Y — X — 1), we know that (Y > X + 1), thus Y — X — 1 at least 1, so answer becomes better.