Блог пользователя alibi

Автор alibi, история, 9 лет назад, По-английски

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!

  • Проголосовать: нравится
  • +5
  • Проголосовать: не нравится

»
9 лет назад, # |
  Проголосовать: нравится +14 Проголосовать: не нравится

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.