#joi2020hoc. [joi2020ho_c]スタンプラリー 3 (Collecting Stamps 3)
[joi2020ho_c]スタンプラリー 3 (Collecting Stamps 3)
JOI 君が住む IOI 国は,大きな湖があることで有名である.今日,湖の周りでスタンプラリー大会が行われることになった.
湖の周りには 個のスタンプ台が設置されており,時計回りに から までの番号が付いている.湖の周りの長さは メートルであり,スタンプ台 () はスタンプラリーのスタート地点から湖の周りに沿って時計回りに メートルだけ進んだ地点に設置されている.
スタンプラリーの各参加者は,スタンプラリー開始時にはスタート地点にいて,スタンプラリー開始後は湖の周りに沿って時計回りもしくは反時計回りに移動することができる.参加者は,スタンプ台が設置されている地点に到着したとき,まだそのスタンプ台でスタンプを押していなかった場合に限り,スタンプを 回だけ押すことができる.ただし,スタンプ台 () はスタンプラリー開始から 秒が経過すると撤去され,それより後に参加者が到着してもそのスタンプ台でスタンプを押すことはできなくなる.なお, 秒ちょうどに参加者が到着した場合については,スタンプを押すことができるとする.
JOI 君はこのスタンプラリー大会の参加者である.JOI 君は メートルを進むのに 秒かかる.また,JOI 君はスタンプを押すことに熟練しているので,スタンプを押すのにかかる時間は無視することができる.
スタンプ台の個数,湖の周りの長さ,各スタンプ台が設置されている地点,各スタンプ台が撤去される時刻が与えられたとき,JOI 君が押すことのできるスタンプの個数の最大値を求めるプログラムを作成せよ.
入力
入力は以下の形式で標準入力から与えられる.入力される値はすべて整数である.
出力
JOI 君が押すことのできるスタンプの個数の最大値を,標準出力に 行で出力せよ.
制約
- .
- .
- ().
- ().
- ().
小課題
- ( 点) ,, ().
- ( 点) .
- ( 点) , ().
- ( 点) 追加の制約はない.
入力例 1
6 25
3 4 7 17 21 23
11 7 17 10 8 10
出力例 1
4
以下のようにすると JOI 君は 個のスタンプを押すことができる.
- 反時計回りに メートル進む.スタンプラリー開始からの経過時間は 秒であるので,スタンプ台 でスタンプを押すことができる.
- さらに反時計回りに メートル進む.スタンプラリー開始からの経過時間は 秒であるので,スタンプ台 でスタンプを押すことができる.
- 時計回りに メートル進む.スタンプラリー開始からの経過時間は 秒であるので,スタンプ台 でスタンプを押すことができる.
- さらに時計回りに メートル進む.スタンプラリー開始からの経過時間は 秒であるので,スタンプ台 でスタンプを押すことはできない.
- さらに時計回りに メートル進む.スタンプラリー開始からの経過時間は 秒であるので,スタンプ台 でスタンプを押すことができる.
どのように移動しても JOI 君が 個以上のスタンプを押すことはできないので, を出力する.
入力例 2
5 20
4 5 8 13 17
18 23 15 7 10
出力例 2
5
JOI 君はスタンプラリー開始後,湖の周りを反時計回りに進み続けることで,すべてのスタンプ台でスタンプを押すことができる.
入力例 3
4 19
3 7 12 14
2 0 5 4
出力例 3
0
残念ながら,JOI 君がどのように移動したとしてもスタンプを押すことはできない.
入力例 4
10 87
9 23 33 38 42 44 45 62 67 78
15 91 7 27 31 53 12 91 89 46
出力例 4
5