結果
問題 | No.1731 Product of Subsequence |
ユーザー |
![]() |
提出日時 | 2021-11-05 23:38:21 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,245 bytes |
コンパイル時間 | 2,529 ms |
コンパイル使用メモリ | 214,828 KB |
最終ジャッジ日時 | 2025-01-25 13:55:25 |
ジャッジサーバーID (参考情報) |
judge10 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 17 WA * 5 TLE * 9 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; #define rep(i, n) for (int i=0; i<(int)(n); ++(i)) #define rep3(i, m, n) for (int i=(m); (i)<(int)(n); ++(i)) #define repr(i, n) for (int i=(int)(n)-1; (i)>=0; --(i)) #define rep3r(i, m, n) for (int i=(int)(n)-1; (i)>=(int)(m); --(i)) #define all(x) (x).begin(), (x).end() const ll mod = (ll)(1e9) + 7; int main() { int n; ll k; cin >> n >> k; vector<ll> a(n); rep(i, n) cin >> a[i]; map<int, int> kprimes; ll kval = k; for (ll i=2; i*i<=kval; ++i) if (kval%i == 0) { kprimes[i] = 0; while (kval%i == 0) { kprimes[i]++; kval /= i; } } if (kval > 1) kprimes[kval] = 1; map<map<int, int>, ll> acnt; rep(i, n) { ll aval = a[i]; map<int, int> aprimes; for (auto pi : kprimes) { aprimes[pi.first] = 0; while (aval%pi.first == 0) { aprimes[pi.first]++; aval /= pi.first; } } auto nacnt = acnt; for (auto pi : acnt) { auto nprimes = pi.first; for (auto pi2 : aprimes) nprimes[pi2.first] = min(kprimes[pi2.first], nprimes[pi2.first]+pi2.second); nacnt[nprimes] = (nacnt[nprimes] + pi.second) % mod; } nacnt[aprimes] = (nacnt[aprimes] + 1) % mod; swap(nacnt, acnt); } cout << acnt[kprimes] << endl; return 0; }