結果
問題 |
No.1731 Product of Subsequence
|
ユーザー |
|
提出日時 | 2025-05-03 18:04:04 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 894 ms / 2,000 ms |
コード長 | 1,393 bytes |
コンパイル時間 | 3,934 ms |
コンパイル使用メモリ | 294,352 KB |
実行使用メモリ | 6,272 KB |
最終ジャッジ日時 | 2025-05-03 18:04:17 |
合計ジャッジ時間 | 12,742 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 31 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; std::vector<std::pair<long long, int>> factor(unsigned long long x) { std::vector<std::pair<long long, int>> ret; if (x % 2 == 0) { for (ret.push_back({2, 0}); x % 2 == 0; x /= 2) ret.back().second++; } for (long long p = 3; p * p <= x; p += 2) { if (x % p == 0) { for (ret.push_back({p, 0}); x % p == 0; x /= p) ret.back().second++; } } if (x != 1) ret.push_back({x, 1}); return ret; } const int md = (int)1e9 + 7; int N, K; int main() { std::ios_base::sync_with_stdio(false); std::cin.tie(nullptr); cin >> N >> K; auto d = factor(K); vector<vector<int>> A(N); for(int i = 0; i < N; i++) { ll a; cin >> a; vector<int> B(d.size()); for(int j = 0; j < d.size(); j++) { while(a % d[j].first == 0) { B[j] += 1; a /= d[j].first; } } A[i] = B; } map<vector<int>, int> dp; dp[vector<int>(d.size())] = 1; for(int i = 0; i < N; i++) { map<vector<int>, int> ndp = dp; for(const auto&[ps, val]: dp) { auto ns = ps; for(int j = 0; j < d.size(); j++) { ns[j] += A[i][j]; ns[j] = min(ns[j], (int)d[j].second); } ndp[ns] += val; ndp[ns] %= md; } swap(dp, ndp); } vector<int> s(d.size()); for(int i = 0; i < d.size(); i++) s[i] = d[i].second; int ans = dp[s]; if(K == 1) ans--; cout << ans << "\n"; }