algo

This documentation is automatically generated by competitive-verifier/competitive-verifier

View the Project on GitHub kuhaku-space/algo

:heavy_check_mark: test/yosupo/math/montmort_number.test.cpp

Code

// 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;
}

Test cases

Env Name Status Elapsed Memory
g++ example_00 :heavy_check_mark: AC 2 ms 3 MB
g++ example_01 :heavy_check_mark: AC 2 ms 3 MB
g++ max_00 :heavy_check_mark: AC 72 ms 7 MB
g++ max_01 :heavy_check_mark: AC 71 ms 7 MB
g++ max_02 :heavy_check_mark: AC 96 ms 7 MB
g++ random_00 :heavy_check_mark: AC 39 ms 5 MB
g++ random_01 :heavy_check_mark: AC 46 ms 5 MB
g++ random_02 :heavy_check_mark: AC 57 ms 6 MB
g++ random_03 :heavy_check_mark: AC 40 ms 5 MB
g++ random_04 :heavy_check_mark: AC 55 ms 6 MB
Back to top page