#include #define rep(i,n) for(int i=0;i<(int)(n);i++) using namespace std; using ll = long long ; using P = pair ; using pll = pair; constexpr int INF = 1e9; constexpr long long LINF = 1e17; constexpr int MOD = 1000000007; constexpr double PI = 3.14159265358979323846; using vec = vector ; using mat = vector; mat mul(mat &A, mat &B,int mod) { mat C(A.size(),vec(B[0].size())); for(int i=0;i 0){ if(n & 1) B = mul(B,A,mod); A = mul(A,A,mod); n >>= 1; } return B; } int main(){ int k,m; cin >> k >> m; ll n; cin >> n; vector p(m),q(m),r(m); rep(i,m) cin >> p[i] >> q[i] >> r[i]; rep(i,m) --p[i],--q[i],--r[i]; auto id = [&](int a,int b){return a+b*k;}; int t = k*k; mat A(t,vector(t,0)); rep(i,m){ A[id(p[i],q[i])][id(q[i],r[i])] = 1; } A = poww(A,n-2,MOD); ll ans = 0; rep(i,k)rep(j,k){ ans = (ans + A[id(0,i)][id(j,0)])%MOD; } cout << ans << endl; return 0; }