007 - プログラミングコンテスト
時間制限 3 秒 / メモリ制限 128 MB / 得点 18 / x 3 /
問題
白虎大学では毎年プログラミングコンテストが開催されています。チームの総数をNとしたとき、チームには1からNのチームIDがそれぞれ割り当てられています。コンテストは全てのチームの得点が0の状態から開始し、L秒間連続して行われます。
今年のコンテストは、テレビで中継されることになりました。コンテストの間テレビに映るのは、その時点で最も得点の高いチームだけです。ただし、該当するチームが複数いるときは、その中でチームIDの一番小さいチームが映ります。映すべきチームが変わると、瞬時にカメラが切り替わります。
あなたはコンテストのログを入手しました。ログには、あるチームの得点が変化した時のレコードがすべて含まれています。各レコードは「チームdがコンテスト開始t秒後の時点でx点獲得した」という形式で与えられています。なお、減点される場合もあるので、現在の得点が0より小さくなることもあります。
コンテストのログを入力とし、コンテスト開始から終了までの間にテレビに映った時間が最も長いチームのIDを報告するプログラムを作成してください。
Input
入力は1つのデータセットからなる。入力は以下の形式で与えられる。
N R L d1 t1 x1 d2 t2 x2 : dR tR xR
1行目は3つの整数からなる。N(2 ≤ N ≤ 100000)はチーム数、R(0 ≤ R ≤ 1000000)はログに含まれるレコードの数である。L(1 ≤ L ≤ 1000000)はコンテストの時間(長さ)を表す。続くR行に各レコードの情報が与えられる。各レコードはチームdi(1 ≤ di ≤ N)がコンテスト開始ti(0 < ti < L)秒後の時点でxi(-1000 ≤ xi ≤ 1000)点獲得あるいは減点されたことを示す。ただし、ti, xiは整数であり、ti-1 ≤ tiである。
Output
コンテスト開始から終了までの間にテレビに映った時間が最も長いチームのIDを1行に出力する。ただし、最も長いチームが複数あるときは、その中でチームIDの一番小さいチームを出力する。
Sample Input 1
3 4 600 3 100 5 1 200 10 2 400 20 3 500 20
Sample Output 1
1
Sample Input 2
3 5 600 3 100 5 1 200 10 2 300 30 1 400 -8 2 400 -27
Sample Output 2
3