#joi2020hod. [joi2020ho_d]オリンピックバス (Olympic Bus)
[joi2020ho_d]オリンピックバス (Olympic Bus)
JOI 国には 個の都市があり, から までの番号が付いている.また,都市と都市を一方向に結ぶ 本のバス路線があり, から までの番号が付いている.バス路線 () は都市 から都市 へ向けて運行されており,運賃は 円である.バス路線 () では,都市 以外で乗ったり,都市 以外で降りることはできない.ある都市からある都市へ向けて運行されるバス路線が複数存在するかもしれない.
JOI 国では間もなくオリンピックが開催される.JOI 国の運輸大臣である 理事長は,バス路線を高々 つ選び,オリンピック期間中,運賃を変更せずにそのバス路線の運行方向を反転させることにした.つまり,バス路線 () を選んだ場合,オリンピック期間中,そのバス路線は都市 から都市 へ向けて運行されるのではなく,都市 から都市 へ向けて運行されるようになる.ただし,バス路線 の運行方向の反転には 円かかり,これは K 理事長のポケットマネーにより賄われる.また,混乱を避けるため,オリンピック期間の途中でバス路線を反転させることはできない.
運輸大臣である K 理事長は,オリンピック期間中,都市 と都市 の間をバス路線を乗り継いで往復する予定である.運行方向を反転させるバス路線をうまく選ぶことで,往復の合計運賃と運行方向の反転の費用との和を最小化したい.
都市の個数と,バス路線の情報が与えられたとき,運行方向を反転させるバス路線をうまく選ぶことで,都市 と都市 の間の往復の合計運賃と,運行方向の反転の費用との和の最小値を求めるプログラムを作成せよ.ただし,どのようにバス路線を選んでも都市 と都市 の間を往復することができない場合は,代わりに を出力せよ.
入力
入力は以下の形式で標準入力から与えられる.入力される値はすべて整数である.
出力
都市 と都市 の間の往復の合計運賃と,運行方向の反転の費用との和の最小値を,標準出力に 行で出力せよ.ただし,どのようにバス路線を選んでも都市 と都市 の間を往復することができない場合は,代わりに を出力せよ.
制約
- .
- .
- ().
- ().
- ().
- ().
- ().
小課題
- ( 点) .
- ( 点) は偶数,,, ().
- ( 点) ().
- ( 点) 追加の制約はない.
入力例 1
4 5
1 2 4 4
1 3 2 1
4 3 1 2
4 1 6 1
2 4 2 5
出力例 1
10
バス路線 の運行方向を費用 で反転させると,都市 から都市 への移動にかかる運賃は最小で ,都市 から都市 への移動にかかる運賃は最小で となり,都市 と都市 の間の往復の合計運賃と,運行方向の反転の費用との和は となる.
都市 と都市 の間の往復の合計運賃と,運行方向の反転の費用との和を より小さくすることはできないので, を出力する.
入力例 2
4 10
1 2 4 4
1 2 4 4
1 3 2 1
1 3 2 1
4 3 1 2
4 3 1 2
4 1 6 1
4 1 6 1
2 4 2 5
2 4 2 5
出力例 2
10
この入出力例は小課題 の制約を満たす.
入力例 3
4 4
1 2 0 4
1 3 0 1
4 3 0 2
4 1 0 1
出力例 3
2
この入出力例は小課題 の制約を満たす.
入力例 4
4 5
1 2 4 4
1 3 2 4
4 3 1 5
4 1 6 1
2 4 2 5
出力例 4
12
バス路線の運行方向を反転させなくてもよい.
入力例 5
4 5
2 1 4 4
1 3 2 1
4 3 1 2
4 3 6 1
2 4 2 5
出力例 5
-1
この入力例では,都市 から都市 へと運行されるバス路線が 本存在する.