#cpsco2019s1g. [cpsco2019_s1_g]Game with Division

[cpsco2019_s1_g]Game with Division

問題文

やむなく君は 11 枚の紙と長さ NN の整数列 A1,A2,ldots,ANA_1, A_2, \\ldots, A_N を使った次のようなゲームを考えました。

まず紙に好きな正の整数を 11 つ書きます。その後 NN 回の操作をします。 ii 回目 (1leileN)(1\\le i\\le N) の操作では以下のどちらか 11 つを行います。

  • その時点で紙に書かれている数字を XX として、Y=leftlfloorfracAiXrightrfloorY = \\left \\lfloor\\frac{A_i}{X}\\right \\rfloor とする (lfloorxrfloor\\lfloor x \\rfloorxx の整数部分を表します)。紙に書かれている数字を YY に書き換えて、YY 点を獲得する。 なおこの操作は X>AiX > A_i のときには行うことができない。
  • 何もしない。得点も獲得できない。

やむなく君は NN 回の操作で獲得する点数の合計を最大化したいです。

やむなく君が最初に紙に書く数字と NN 回の操作を最適に行ったときに獲得できる点数を求めてください。

制約

  • 1leNle10001\\le N\\le 1000
  • 1leAile1061\\le A_i\\le 10^6
  • 入力はすべて整数

部分点

この問題には部分点が設定されています。

  • すべての i(1leileN)i\\ (1\\le i\\le N) について Aile1000A_i\\le 1000 を満たす入力に正解すると、300300 点が与えられます。

入力

入力は以下の形式で標準入力から与えられます。

NN A1A2ldotsANA_1\\ A_2\\ \\ldots\\ A_N

出力

やむなく君の獲得できる点数の最大値を 11 行に出力してください。


入力例 1

3
3 6 9

出力例 1

10
  • まず紙に 22 と書く。
  • 11 回目の操作では紙の数字を leftlfloorfrac32rightrfloor=1\\left \\lfloor\\frac{3}{2}\\right \\rfloor = 1 に書き換えて 11 点を獲得する。
  • 22 回目の操作では何もしない。
  • 33 回目の操作では紙の数字を leftlfloorfrac91rightrfloor=9\\left \\lfloor\\frac{9}{1}\\right \\rfloor = 9 に書き換えて 99 点を獲得する。

このとき合計 1010 点を獲得できて、これが最大です。なお、1010 点を獲得する方法は他にもあります。


入力例 2

3
10 3 4

出力例 2

10

入力例 3

1
1000

出力例 3

1000

入力例 4

10
87 72 55 81 12 59 1 10 18 53

出力例 4

166