#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define all(a) a.begin(),a.end() #define rep(i, n) for (ll i = 0; i < (n); i++) #define pb push_back #define debug(x) cerr << #x << ':' << x << '\n'; #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") using namespace std; typedef long long ll; typedef unsigned long long ull; typedef long double ld; typedef pair P; typedef complex com; constexpr int inf = 1000000010; constexpr ll INF = 1000000000000000010; constexpr ld eps = 1e-12; constexpr ld pi = 3.141592653589793238; template inline bool chmax(T &a, const U &b) { if (a < b) { a = b; return true; } return false; } template inline bool chmin(T &a, const U &b) { if (a > b) { a = b; return true; } return false; } constexpr ll mod = 1000000007; ll dp[310][310][310]; struct edge { ll from, to, cost; }; int main() { cin.tie(0); ios::sync_with_stdio(false); cout << fixed << setprecision(20); ll n, m, k; cin >> n >> m >> k; vector a(m); rep(i, m) { ll u, v, c; cin >> u >> v >> c; u--; v--; a[i] = { u,v,c }; } rep(i, 300) dp[0][i][0] = 1; rep(i, n - 1) { rep(j, m) { rep(x, 300) { if (x + a[j].cost <= k) { dp[i + 1][a[j].to][x + a[j].cost] += dp[i][a[j].from][x]; dp[i + 1][a[j].to][x + a[j].cost] %= mod; } } } } ll ans = 0; rep(i, 300) ans += dp[n - 1][i][k]; cout << ans % mod << '\n'; }