結果
問題 |
No.1749 ラムドスウイルスの感染拡大
|
ユーザー |
|
提出日時 | 2021-11-19 22:42:42 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,780 bytes |
コンパイル時間 | 1,742 ms |
コンパイル使用メモリ | 167,540 KB |
実行使用メモリ | 18,816 KB |
最終ジャッジ日時 | 2025-01-01 20:29:20 |
合計ジャッジ時間 | 3,277 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 13 WA * 13 |
ソースコード
#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<vector<ll>> v(n,vector<ll>(t+1)); v[0][0] = 1; vector<vector<ll>> vv(n,vector<ll>(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; }