#dpg. [dp_g]Longest Path

[dp_g]Longest Path

問題文

NN 頂点 MM 辺の有向グラフ GG があります。 頂点には 1,2,ldots,N1, 2, \\ldots, N と番号が振られています。 各 ii (1leqileqM1 \\leq i \\leq M) について、ii 番目の有向辺は頂点 xix_i から yiy_i へ張られています。 GG有向閉路を含みません

GG の有向パスのうち、最長のものの長さを求めてください。 ただし、有向パスの長さとは、有向パスに含まれる辺の本数のことです。

制約

  • 入力はすべて整数である。
  • 2leqNleq1052 \\leq N \\leq 10^5
  • 1leqMleq1051 \\leq M \\leq 10^5
  • 1leqxi,yileqN1 \\leq x_i, y_i \\leq N
  • ペア (xi,yi)(x_i, y_i) はすべて相異なる。
  • GG有向閉路を含まない

入力

入力は以下の形式で標準入力から与えられる。

NN MM x1x_1 y1y_1 x2x_2 y2y_2 :: xMx_M yMy_M

出力

GG の有向パスのうち、最長のものの長さを出力せよ。


入力例 1

4 5
1 2
1 3
3 2
2 4
3 4

出力例 1

3

次図の赤い有向パスが最長です。


入力例 2

6 3
2 3
4 5
5 6

出力例 2

2

次図の赤い有向パスが最長です。


入力例 3

5 8
5 3
2 3
2 4
5 2
5 1
1 4
4 3
1 3

出力例 3

3

例えば、次図の赤い有向パスが最長です。