제출 #557777

#제출 시각아이디문제언어결과실행 시간메모리
557777Yazan_AlattarSemafor (COI20_semafor)C++14
6 / 100
4 ms340 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef unsigned long long ull; #define F first #define S second #define pb push_back #define endl "\n" #define all(x) x.begin(), x.end() const int M = 10007; const ll inf = 2e9; const ll mod = 1e9 + 7; const double pi = acos(-1); const double eps = 1e-6; const int dx[] = {0, -1, 0, 1}, dy[] = {1, 0, -1, 0}; const int block = 320; struct Matrix{ vector < vector <ll> > a = vector < vector <ll> > (32, (vector <ll> (32))); Matrix operator *(Matrix b){ Matrix ret; for(int i = 0; i < 32; ++i) for(int j = 0; j < 32; ++j) for(int k = 0; k < 32; ++k){ ret.a[i][k] = (ret.a[i][k] + (a[i][j] * b.a[j][k])) % mod; } return ret; } }; Matrix Pow(Matrix x, ll p) { Matrix ret; for(int i = 0; i < 32; ++i) ret.a[i][i] = 1; while(p){ if(p % 2) ret = ret * x; x = x * x; p /= 2; } return ret; } ll m, n, k, x, sticks[M], ans[20]; bool vist[50]; int main(){ ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); // =======Construction========= sticks[1] = 2; sticks[2] = 9; sticks[3] = 7; sticks[4] = 18; sticks[5] = 21; sticks[6] = 12; sticks[7] = 3; sticks[8] = 29; sticks[9] = 23; sticks[0] = 10; vist[2] = vist[9] = 1; vist[7] = vist[18] = 1; vist[21] = vist[12] = 1; vist[3] = vist[29] = 1; vist[23] = vist[10] = 1; // ============================= cin >> m >> n >> k >> x; Matrix init; for(int i = 0; i < 32; ++i) for(int j = 0; j < 5; ++j) init.a[i][i ^ (1 << j)] = 1; Matrix res = Pow(init, k); Matrix FinalRes = Pow(init, n % k); for(int i = 0; i < 32; ++i) for(int j = 0; j < 32; ++j) init.a[i][j] = 0; for(int i = 0; i <= 9; ++i) for(int j = 0; j <= 9; ++j) init.a[sticks[i]][sticks[j]] = res.a[sticks[i]][sticks[j]]; Matrix dpRes = Pow(init, n / k - 1); for(int i = 0; i <= 9; ++i) for(int j = 0; j <= 9; ++j) for(int l = 0; l <= 9; ++l) ans[i] = (ans[i] + res.a[sticks[x]][sticks[j]] * dpRes.a[sticks[j]][sticks[l]] * FinalRes.a[sticks[l]][sticks[i]]); for(int i = 0; i <= 9; ++i) cout << ans[i] << endl; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...