結果

問題 No.1731 Product of Subsequence
ユーザー shobonvipshobonvip
提出日時 2023-05-26 21:13:16
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
TLE  
実行時間 -
コード長 1,060 bytes
コンパイル時間 4,250 ms
コンパイル使用メモリ 275,768 KB
実行使用メモリ 53,540 KB
最終ジャッジ日時 2024-12-25 04:16:36
合計ジャッジ時間 55,682 ms
ジャッジサーバーID
(参考情報)
judge3 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 TLE -
testcase_01 AC 2 ms
10,496 KB
testcase_02 AC 2 ms
25,984 KB
testcase_03 AC 2 ms
13,640 KB
testcase_04 AC 1 ms
24,192 KB
testcase_05 AC 3 ms
10,496 KB
testcase_06 AC 2 ms
10,496 KB
testcase_07 AC 2 ms
13,644 KB
testcase_08 TLE -
testcase_09 AC 4 ms
13,636 KB
testcase_10 TLE -
testcase_11 TLE -
testcase_12 AC 3 ms
10,496 KB
testcase_13 AC 6 ms
13,644 KB
testcase_14 TLE -
testcase_15 AC 1 ms
13,636 KB
testcase_16 AC 1 ms
10,496 KB
testcase_17 AC 2 ms
11,776 KB
testcase_18 TLE -
testcase_19 AC 8 ms
10,496 KB
testcase_20 TLE -
testcase_21 TLE -
testcase_22 AC 4 ms
34,816 KB
testcase_23 AC 3 ms
10,496 KB
testcase_24 TLE -
testcase_25 TLE -
testcase_26 TLE -
testcase_27 TLE -
testcase_28 TLE -
testcase_29 TLE -
testcase_30 TLE -
testcase_31 AC 5 ms
5,248 KB
testcase_32 AC 3 ms
5,248 KB
testcase_33 AC 5 ms
5,248 KB
testcase_34 TLE -
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

#include<bits/stdc++.h>
#include<atcoder/all>
using namespace std;
using namespace atcoder;
typedef modint1000000007 mint;
typedef long long ll;
vector<pair<int,int>> pfact(int n){
vector<pair<int,int>> ret;
for (int i=2; i*i<=n; i++){
if (n%i == 0){
int cnt = 0;
while (n%i == 0){
n /= i;
cnt++;
}
ret.push_back(pair(i, cnt));
}
}
if (n > 1) ret.push_back(pair(n, 1));
return ret;
}
int main(){
int n, k; cin >> n >> k;
vector<pair<int,int>> pf = pfact(k);
vector<int> pl;
for (auto [p,c]: pf){
pl.push_back(p);
}
vector<ll> a(n);
for (int i=0; i<n; i++){
cin >> a[i];
ll nw = 1;
for (int j: pl){
while (a[i] % j == 0){
nw *= j;
a[i] /= j;
}
}
a[i] = nw % k;
}
map<int,mint> s;
s[1] = 1;
for (int i=0; i<n; i++){
map<int,mint> ns = s;
for (auto j=s.begin(); j!=s.end(); j++){
int tmp = (ll)j->first * a[i] % k;
if (ns.find(tmp) == ns.end()){
ns[tmp] = 0;
}
ns[tmp] += j->second;
}
s = ns;
}
if (s.find(0) == s.end()){
s[0] = 0;
}
cout << s[0].val() << endl;
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0