Time Limit: 2 sec / Memory Limit: 256 MB
問題文
小学生の高橋君は、縞模様が大好きです。今、高橋君は、左から右に一直線上に並んだ 枚の色画用紙を眺めています。高橋君は縞模様がとても好きなので、いくつかの画用紙を絵の具で新しい色に塗り替えることで、全体に見て縞模様になっているようにしたいと思っています。
全体的に見て縞模様であるとは、全体で使用される色がちょうど つであって、全ての画用紙についてそれと隣り合う画用紙との色が異なっている状態のことを指します。
あなたの仕事は、既に配置されている画用紙の枚数 と、 枚の画用紙を別の色に塗り替えるためにかかる絵の具の費用 が与えられるので、縞模様の達成に必要な合計費用の最小値を出力するプログラムを作ってあげることです。 この問題では便宜上、それぞれの色が ~ の 種類の数として与えられます。塗り替えるために使える絵の具の色もこの 種類のみです。
入力
入力は以下の形式で標準入力から与えられる。
:
- 行目には、画用紙の枚数を表す整数 と、画用紙を 枚塗り替えるために必要な絵の具の費用 が与えられる。
- 行目から 行では、既に配置された画用紙の色がそれぞれ与えられる。このうち 行目では一直線上に並んだ画用紙のうち左から 番目の色をそれぞれ表す整数 が与えられる。
出力
縞模様を達成するのに必要な合計費用の最小値を 行に出力せよ。出力の末尾にも改行をいれること。
入力例1
- 3 10
- 3
- 2
- 1
3 10 3 2 1
出力例1
- 10
10
塗られている色は、左から順番に である。 番目の「3」を「1」に塗り替えれば となる。また、 番目の「1」を「3」に塗り替えれば となる。
これらはどちらも縞模様を達成していて、かつどちらの場合も 枚の画用紙を塗り替える必要があり、合計費用は である。従って を出力すればよい。
入力例2
- 4 100
- 1
- 1
- 1
- 1
4 100 1 1 1 1
出力例2
- 200
200
入力例3
- 10 1000
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
10 1000 1 2 3 4 5 6 7 8 9 10
出力例3
- 8000
8000