Time Limit: 1 sec / Memory Limit: 256 MB
配点: 点
あなたは Just Odd Inventions 社を知っているだろうか?この会社の業務は「ただ奇妙な発明 (just odd inventions)」をすることである.ここでは略して JOI 社と呼ぶ.
JOI 社は新商品「長いだけのネクタイ」を開発した.ネクタイは 種類あり,各種類には から までの番号がついている. 番目 () の種類のネクタイの長さは である.
JOI 社は社員を集め,ネクタイの試着会を行うことにした.試着会には 人の社員が参加し, 人目 () の社員がはじめに付けているネクタイの長さは である.
試着会は以下の手順で行われる予定である.
- まず,試着会で使わないネクタイを 種類選ぶ.
- 次に,各社員はそれ以外のネクタイから試着するネクタイを 種類選ぶ.ただし,どの 人も同じ種類のネクタイを選ばないようにする.
- 最後に,各社員は今付けているネクタイを外し,先ほど選んだネクタイを試着する.
長さ のネクタイを付けていた社員が,長さ のネクタイを試着すると大きさ の奇妙さを感じる.(ここで, は, と のうち小さくない方を表す.) 試着会において各社員の感じる奇妙さの最大値を,その試着会の奇妙さとする.
試着会で使わないネクタイが 番目の種類のネクタイのとき,試着会の奇妙さとして考えられる最小の値を とする.
各種類のネクタイの長さ,各社員がはじめに付けているネクタイの長さが与えられた時, の値を求めるプログラムを作成せよ.
入力
入力は以下の形式で標準入力から与えられる.入力される値はすべて整数である.
出力
の値を,空白区切りで標準出力に 行で出力せよ.
制約
- .
- ().
- ().
小課題
- ( 点) .
- ( 点) .
- ( 点) 追加の制約はない.
入力例 1Copy
3 4 3 7 6 2 6 4
出力例 1Copy
2 2 1 1
例えば,試着会は次のように行われる.
- 番目の種類のネクタイを使わないことにする.
- 社員 が 番目の,社員 が 番目の,社員 が 番目の種類のネクタイを選ぶ.
- 各社員が試着する.
このとき,各社員が感じる奇妙さは順に となるから,この試着会の奇妙さは である.
社員が選ぶネクタイを変えることで、試着会の奇妙さを にすることができる.例えば,試着会を次のように行うとする.
- 番目の種類のネクタイを使わないことにする.
- 社員 が 番目の,社員 が 番目の,社員 が 番目の種類のネクタイを選ぶ.
- 各社員が試着する.
このとき,各社員が感じる奇妙さは順に となるから,この試着会の奇妙さは である.
これが 番目の種類のネクタイを使わない場合の試着会の奇妙さの最小値なので, である.
入力例 2Copy
5 4 7 9 10 11 12 3 5 7 9 11
出力例 2Copy
4 4 3 2 2 2