#dpn. [dp_n]Slimes

[dp_n]Slimes

問題文

NN 匹のスライムが横一列に並んでいます。 最初、左から ii 番目のスライムの大きさは aia_i です。

太郎君は、すべてのスライムを合体させて 11 匹のスライムにしようとしています。 スライムが 11 匹になるまで、太郎君は次の操作を繰り返し行います。

  • 左右に隣り合う 22 匹のスライムを選び、それらを合体させて新しい 11 匹のスライムにする。 合体前の 22 匹のスライムの大きさを xx および yy とすると、合体後のスライムの大きさは x+yx + y となる。 このとき、太郎君は x+yx + y のコストを支払う。 なお、合体の前後でスライムたちの位置関係は変わらない。

太郎君が支払うコストの総和の最小値を求めてください。

制約

  • 入力はすべて整数である。
  • 2leqNleq4002 \\leq N \\leq 400
  • 1leqaileq1091 \\leq a_i \\leq 10^9

入力

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

NN a1a_1 a2a_2 ldots\\ldots aNa_N

出力

太郎君が支払うコストの総和の最小値を出力せよ。


入力例 1

4
10 20 30 40

出力例 1

190

次のように操作を行えばよいです。 操作対象のスライムを太字で表しています。

  • (10, 20, 30, 40) → (30, 30, 40)
  • (30, 30, 40) → (60, 40)
  • (60, 40) → (100)

入力例 2

5
10 10 10 10 10

出力例 2

120

例えば、次のように操作を行えばよいです。

  • (10, 10, 10, 10, 10) → (20, 10, 10, 10)
  • (20, 10, 10, 10) → (20, 20, 10)
  • (20, 20, 10) → (20, 30)
  • (20, 30) → (50)

入力例 3

3
1000000000 1000000000 1000000000

出力例 3

5000000000

答えは 32-bit 整数型に収まらない場合があります。


入力例 4

6
7 6 8 6 1 1

出力例 4

68

例えば、次のように操作を行えばよいです。

  • (7, 6, 8, 6, 1, 1) → (7, 6, 8, 6, 2)
  • (7, 6, 8, 6, 2) → (7, 6, 8, 8)
  • (7, 6, 8, 8) → (13, 8, 8)
  • (13, 8, 8) → (13, 16)
  • (13, 16) → (29)