QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#85315 | #5661. Multi-Ladders | piasticOuO | AC ✓ | 2ms | 3408kb | C++14 | 1.4kb | 2023-03-07 15:56:48 | 2023-03-07 15:56:52 |
Judging History
answer
#include <iostream>
using namespace std;
const int mo = 1e9 + 7;
int T;
long long n, k, u;
long long Ln, ans;
struct Matrix {
int numH, numL;
long long a[5][5] = {0};
Matrix operator*(Matrix mt) {
Matrix res;
res.numL = numL;
res.numH = mt.numH;
for (int i = 1; i <= res.numL; ++i) {
for (int j = 1; j <= res.numH; ++j) {
for (int k = 1; k <= numH; ++k) {
res.a[i][j] = (res.a[i][j] + a[i][k] * mt.a[k][j]) % mo;
}
}
}
return res;
}
};
Matrix Omt, Emt;
long long qc(long long x, long long y) {
long long res = 1;
while (y) {
if (y & 1)
res = res * x % mo;
x = x * x % mo;
y >>= 1;
}
return res;
}
Matrix mtqc(Matrix a, long long x) {
Matrix res = Emt;
while (x) {
if (x & 1)
res = res * a;
a = a * a;
x >>= 1;
}
return res;
}
void solve() {
cin >> n >> k >> u;
long long d = ((u - 2) * (u - 2) - 1 + u) % mo; //һ\xb8\xf6\xc6\xe6\xc3\xee\xb5ij\xa3\xca\xfd
Ln = qc(d, k * (n - 1));
Omt.numH = Omt.numL = 2;
Omt.a[1][1] = u - 2, Omt.a[1][2] = u - 1;
Omt.a[2][1] = 1, Omt.a[2][2] = 0;
Matrix fmt = mtqc(Omt, k - 2);
long long c = u * (u - 1) % mo * fmt.a[1][1] % mo;
ans = c * Ln % mo;
cout << ans << '\n';
}
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
Emt.numH = Emt.numL = 2;
Emt.a[1][1] = Emt.a[2][2] = 1; //2*2\xb5\xa5λ\xbe\xd8\xd5\xf3
cin >> T;
while (T--) {
solve();
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 2ms
memory: 3396kb
input:
1 2 3 3
output:
162
result:
ok single line: '162'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3408kb
input:
20 2 3 3 1 3 3 10 3 0 10 3 2 1 21 2 1 22 0 2000 15000 2000 12000 30000 200000 1000000000 3 3 2 1000000000 3 2 3 100000000 1000000000 1000000000 10 1000000000 3 100000000 2 1000000000 100000000 1 1000000000 10 1 1000000000 100000000 1 1000 100000000 1000000000 1000000000 0 1000000000 1000000000 1 100...
output:
162 6 0 0 0 0 349400141 243010659 52489881 53690844 176686901 218103365 558243892 991895211 693053429 883715672 80402569 0 0 311752813
result:
ok 20 lines