两个条件综合起来加上求最大的节点数,那么很明显如果是环一定要缩点。
然后再仔细思考下就是求dag的最长路的数目啦。。。
然后wa了。。。
看了题解。。。噗!第一次注意到缩点后会有重边QAQ。。。于是。。
orz orz
然后思考了下怎么处理重边。。。很简单,每个点bfs时记录一下就行了。。
#include #include #include #include #include #include #include #include #include
Description
Input
第一行包含两个整数N,M,X。N,M分别表示图G的点数与边数,X的意义如上文所述。接下来M行,每行两个正整数a, b,表示一条有向边(a, b)。图中的每个点将编号为1,2,3…N,保证输入中同一个(a,b)不会出现两次。
Output
应包含两行,第一行包含一个整数K。第二行包含整数C Mod X.
Sample Input
6 6 20070603
1 2
2 1
1 3
2 4
5 6
6 4
Sample Output
HINT
对于100%的数据, N ≤100000, M ≤1000000;对于100%的数据, X ≤10^8。
Source