|
2012年12月16日
情報オリンピック日本委員会
|
日本が冬であるこの時期,南半球にあるオーストラリアでは暑い日が続いている.オーストラリアに住む IOI 君は,ある D 日間の天気予報をもとに,着る服の計画を立てることにした.i 日目 (1 ≦ i ≦ D) の最高気温は Ti 度であると予報されている.
IOI 君は N 種類の服を持っており,それらには 1 から N までの番号がついている.服 j (1 ≦ j ≦ N) は最高気温が Aj 度以上 Bj 度以下の日に着るのに適している.また,それぞれの服には「派手さ」とよばれる整数が定まっており,服 j の派手さは Cj である.
D 日間のそれぞれに対し,IOI 君は,最高気温が天気予報に従ったときに着るのに適した服のうち 1 つを着る服として選ぶ.同じ服を何度選んでもよいし,D 日間で一度も選ばれない服があってもよい.
似ている服を連続して着ることをなるべく避けようと思った IOI 君は,連続する日に着る服の派手さの差の絶対値の合計をできるだけ大きくしようと考えた.すなわち,i 日目に服 xi を選んだとして,値 |Cx1 - Cx2| + |Cx2 - Cx3| + … + |CxD-1 - CxD| を最大にしたい.この最大値を求めるプログラムを作成せよ.
入力は 1 + D + N 行からなる.
1 行目には,2 つの整数 D, N (2 ≦ D ≦ 200,1 ≦ N ≦ 200) が空白を区切りとして書かれている.D は服の計画を立てる日数,N は IOI 君が持っている服の種類の数を表す.
続く D 行のうちの i 行目 (1 ≦ i ≦ D) には,1 つの整数 Ti (0 ≦ Ti ≦ 60) が書かれている.これは,i 日目の最高気温が Ti 度であると予報されていることを表す.
続く N 行のうちの j 行目 (1 ≦ j ≦ N) には,3 つの整数 Aj, Bj, Cj (0 ≦ Aj ≦ Bj ≦ 60,0 ≦ Cj ≦ 100) が書かれている.これらは,服 j は最高気温が Aj 度以上 Bj 度以下の日に着るのに適しており,派手さが Cj であることを表す.
最高気温が天気予報に従ったときに着るのに適した服が,D 日間のどの日に対しても 1 つ以上存在することが保証されている.
連続する日に着る服の派手さの差の絶対値の合計,すなわち,値 |Cx1 - Cx2| + |Cx2 - Cx3| + … + |CxD-1 - CxD| の最大値を 1 行で出力せよ.
入力例 1 | 入力例 2 |
---|---|
3 4 31 27 35 20 25 30 23 29 90 21 35 60 28 33 40 |
5 2 26 28 32 29 34 30 35 0 25 30 100 |
出力例 1 | 出力例 2 |
80 |
300 |
入出力例 1 において,1 日目の服の候補は服 3 と服 4 であり,2 日目の服の候補は服 2 と服 3 であり,3 日目の服の候補は服 3 のみである.1 日目に服 4 を,2 日目に服 2 を,3 日目に服 3 を選ぶ.すなわち,x1 = 4,x2 = 2,x3 = 3 とする.このとき,1 日目と 2 日目の服の派手さの差の絶対値は |40 - 90| = 50 であり,2 日目と 3 日目の服の派手さの差の絶対値は |90 - 60| = 30 である.合計は 80 となり,これが最大値である.
入出力例 2 において,1 日目には服 2 を,2 日目には服 2 を,3 日目には服 1 を,4 日目には服 2 を,5 日目には服 1 を選ばなければならない.このとき,求める値は |100 - 100| + |100 - 0| + |0 - 100| + |100 - 0| = 300 となる.
※各入出力例のデータは, 右クリック等によりファイルに保存して利用可能です.