比赛 |
矩阵乘法练习赛 |
评测结果 |
TTTTTTTTTT |
题目名称 |
递推关系 |
最终得分 |
0 |
用户昵称 |
ht骨架 |
运行时间 |
19.983 s |
代码语言 |
C++ |
内存使用 |
3.17 MiB |
提交时间 |
2025-04-28 20:39:28 |
显示代码纯文本
#include <bits/stdc++.h>
using namespace std;
long long n, m, d, a[1085], b[1085], f[1085];
int main () {
freopen ("recurrences.in", "r", stdin);
freopen ("recurrences.out", "w", stdout);
for (;;) {
cin >> d >> n >> m;
if (d == 0 && n == 0 && m == 0) {
return 0;
}
for (int i = 1; i <= d; i++) cin >> a[i], a[i] %= m;
for (int i = 1; i <= d; i++) cin >> f[i], f[i] %= m;
if (n <= d) {
cout << f[n] % m << endl;
} else {
for (int i = d + 1; i <= n; i++) {
f[d + 1] = 0;
for (int j = 1; j <= d; ++j) {
f[d + 1] += a[j] * f[d - j + 1] % m;
f[d + 1] %= m;
}
for (int j = 1; j <= d; ++j) {
f[j] = f[j + 1];
}
}
cout << f[d] % m<< endl;
}
}
return 0;
}