This documentation is automatically generated by competitive-verifier/competitive-verifier
// competitive-verifier: PROBLEM https://judge.yosupo.jp/problem/montmort_number_mod
#include <cstdint>
#include <iostream>
#include <vector>
int main(void) {
int n, m;
std::cin >> n >> m;
std::int64_t sum = 0;
std::vector<int> ans(n);
for (int i = 0; i < n; ++i) {
ans[i] = sum;
sum *= i + 2;
if (i & 1) sum += m - 1;
else ++sum;
sum %= m;
}
for (int i = 0; i < (int)ans.size(); ++i)
std::cout << ans[i] << (i == (int)ans.size() - 1 ? '\n' : ' ');
return 0;
}
#line 1 "test/yosupo/math/montmort_number.test.cpp"
// competitive-verifier: PROBLEM https://judge.yosupo.jp/problem/montmort_number_mod
#include <cstdint>
#include <iostream>
#include <vector>
int main(void) {
int n, m;
std::cin >> n >> m;
std::int64_t sum = 0;
std::vector<int> ans(n);
for (int i = 0; i < n; ++i) {
ans[i] = sum;
sum *= i + 2;
if (i & 1) sum += m - 1;
else ++sum;
sum %= m;
}
for (int i = 0; i < (int)ans.size(); ++i)
std::cout << ans[i] << (i == (int)ans.size() - 1 ? '\n' : ' ');
return 0;
}
| Env | Name | Status | Elapsed | Memory |
|---|---|---|---|---|
| g++ | example_00 |
|
2 ms | 3 MB |
| g++ | example_01 |
|
2 ms | 3 MB |
| g++ | max_00 |
|
72 ms | 7 MB |
| g++ | max_01 |
|
71 ms | 7 MB |
| g++ | max_02 |
|
96 ms | 7 MB |
| g++ | random_00 |
|
39 ms | 5 MB |
| g++ | random_01 |
|
46 ms | 5 MB |
| g++ | random_02 |
|
57 ms | 6 MB |
| g++ | random_03 |
|
40 ms | 5 MB |
| g++ | random_04 |
|
55 ms | 6 MB |