結果
問題 | No.2176 LRM Question 1 |
ユーザー |
|
提出日時 | 2023-01-07 00:41:32 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 34 ms / 2,000 ms |
コード長 | 2,013 bytes |
コンパイル時間 | 1,140 ms |
コンパイル使用メモリ | 131,504 KB |
最終ジャッジ日時 | 2025-02-10 00:45:40 |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 |
ソースコード
#include <algorithm> #include <array> #include <bitset> #include <cassert> #include <chrono> #include <cmath> #include <cstdint> #include <cstring> #include <ctime> #include <deque> #include <iomanip> #include <iostream> #include <map> #include <numeric> #include <queue> #include <random> #include <set> #include <sstream> #include <stack> #include <tuple> #include <unordered_map> #include <unordered_set> #include <utility> #include <vector> template <typename T> struct DSU { std::vector<T> f, siz; DSU(int n) : f(n), siz(n, 1) { std::iota(f.begin(), f.end(), 0); } T leader(T x) { while (x != f[x]) x = f[x] = f[f[x]]; return x; } bool same(T x, T y) { return leader(x) == leader(y); } bool merge(T x, T y) { x = leader(x); y = leader(y); if (x == y) return false; siz[x] += siz[y]; f[y] = x; return true; } T size(int x) { return siz[leader(x)]; } }; std::pair<std::vector<long long>, std::vector<int>> get_prime_factor_with_kinds( long long n) { std::vector<long long> prime_factors; std::vector<int> cnt; // number of i_th factor for (long long i = 2; i <= sqrt(n); i++) { if (n % i == 0) { prime_factors.push_back(i); cnt.push_back(0); while (n % i == 0) n /= i, cnt[(int)prime_factors.size() - 1]++; } } if (n > 1) prime_factors.push_back(n), cnt.push_back(1); assert(prime_factors.size() == cnt.size()); return {prime_factors, cnt}; } void solve() { long long l, r, m; std::cin >> l >> r >> m; if (l >= m) { std::cout << 0 << '\n'; return; } r = std::min(r, m - 1); long long f = 1, g = 1; for (long long i = 2; i < l; i++) { f = f * i % m; g = g * f % m; } long long ans = 0; for (long long i = l; i <= r; i++) { f = f * i % m; g = g * f % m; ans += g; ans %= m; } std::cout << ans << '\n'; } int main() { std::cin.tie(nullptr); std::ios::sync_with_stdio(false); int t = 1; // std::cin >> t; while (t--) solve(); // solve(); return 0; }