#include "bits/stdc++.h" #pragma warning(disable : 4996) typedef long long ll; #define all(x) (x).begin(), (x).end() // sortなどの引数を省略 #define rep(i, n) for (ll i = 0; i < (ll)(n); i++) #define max3(x, y, z) max(x, max(y, z)) #define min3(x, y, z) min(x, min(y, z)) #ifdef _MSC_FULL_VER //デバッグ出力 #define dout cout #define debug() if (true) #define check(x) std::cout << "★" << #x << "の値:" << (x) << endl #define pass(x) std::cout << "☆" << x << endl #else #define dout \ if (false) \ cout #define debug() if (false) #define check(x) \ if (false) \ cout << "★" << #x << "の値:" << (x) << endl #define pass(x) \ if (false) \ cout << "☆" << x << endl #endif using namespace std; //#define int long long; double dist(double x1, double y1, double x2, double y2) { return sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2)); } ll idist(ll x1, ll y1, ll x2, ll y2) { return (x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2); } signed main() { ll n,m,t; cin >> n >> m >> t; vector> v(n,vector(t+1)); v[0][0] = 1; vector> vv(n,vector(n)); rep(i,m){ ll s,t; cin >> s >> t; vv[s][t] = vv[t][s] = 1; } for(int d = 1;d <= t;d++){ rep(i,n){ if(v[i][d-1] > 0){ rep(j,n){ if(vv[i][j] == 1){ v[j][d] += v[i][d-1]; } } } } } cout << v[0][t] % 998244353 << endl; /*rep(i,n){ rep(j,t+1){ cout << v[i][j] << " "; } cout << endl; } rep(i,n){ rep(j,n){ cout << vv[j][i]; } cout << endl; }*/ return 0; }