問題文
L個のマスが左右に一列に並んでいます。いくつかのマスの上に駒が置いてあります。駒には左向きか右向きの矢印が書いてあります。なお、一つのマスに二つ以上の駒を置くことはできません。
どのマスにいる駒も、駒が置かれていないマスに動かすことができます。ただし、一度に動けるのは隣のマスまでで、一度に動かせるのは一つの駒だけです。駒は、矢印の向きにかかわらず、左にも右にも動かすことができます。ただし、駒を矢印の方向に一回動かすと点数が1点もらえますが、矢印とは逆方向に一回動かすと1点減点されてしまいます。なお、どのような状況から始めたとしても、得られる点数には必ず最大値があることがわかっています。
マスの個数と駒の状況が与えられたとき、得られる最大の点数を計算するプログラムを作成せよ。ただし、マスには列の左端から順番に1からLまでの番号が割り当てられているものとする。
入力
入力は以下の形式で与えられる。
N L p1 d1 p2 d2 : pN dN
1行目に駒の数N (1≤N≤105)とマスの数L (N≤L≤109)が与えられる。続くN行に駒が置かれたマスの番号pi (1≤pi≤L)と駒に書かれた矢印の向きdi (0または1)が与えられる。ただし、diが0のときは矢印が左向き、1のときは右向きを表す。同じマスの番号は与えられない(i≠jについて、pi≠pj)。
出力
得られる最大の点数を1行に出力する。
入出力例
入力例1
2 10 3 0 6 1
出力例1
6
入力例2
2 8 2 1 8 0
出力例2
5
入力例3
2 8 1 0 8 1
出力例3
0