結果
問題 | No.2211 Frequency Table of GCD |
ユーザー |
![]() |
提出日時 | 2023-02-27 01:18:13 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 414 ms / 2,000 ms |
コード長 | 3,276 bytes |
コンパイル時間 | 3,384 ms |
コンパイル使用メモリ | 254,488 KB |
最終ジャッジ日時 | 2025-02-10 23:47:32 |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 26 |
ソースコード
#include <bits/stdc++.h>#include <atcoder/all>using namespace atcoder;using namespace std;using ll=long long;using ld=double;ld pie=3.14159265359;ll mod=998244353;long long inf=100000000000000001;struct Eratosthenes {// テーブルvector<bool> isprime;// 整数 i を割り切る最小の素数vector<ll> minfactor;vector<ll>mobius;// コンストラクタで篩を回すEratosthenes(ll N) : isprime(N+1, true),minfactor(N+1, -1),mobius(N+1,1) {// 1 は予めふるい落としておくisprime[1] = false;minfactor[1] = 1;// 篩for (ll p = 2; p <= N; ++p) {// すでに合成数であるものはスキップするif (!isprime[p]) continue;// p についての情報更新minfactor[p] = p;mobius[p]=-1;// p 以外の p の倍数から素数ラベルを剥奪for (ll q = p * 2; q <= N; q += p) {// q は合成数なのでふるい落とすisprime[q] = false;// q は p で割り切れる旨を更新if (minfactor[q] == -1) minfactor[q] = p;if ((q / p) % p == 0) mobius[q] = 0;else mobius[q] = -mobius[q];}}}// 高速素因数分解// pair (素因子, 指数) の vector を返すvector<pair<ll,ll>> factorize(ll n) {vector<pair<ll,ll>> res;while (n > 1) {ll p = minfactor[n];ll exp = 0;// n で割り切れる限り割るwhile (minfactor[n] == p) {n /= p;++exp;}res.emplace_back(p, exp);}return res;}vector<ll>divisors(ll n){vector<ll>res({1});auto pf=factorize(n);for (auto p : pf){ll s=(ll)res.size();for (ll i = 0; i < s; i++){ll v=1;for (ll j = 0; j < p.second; j++){v*=p.first;res.push_back(res[i]*v);}}}return res;}};ll modpow(ll x, ll n) {x = x%mod;if(n==0) return 1; //再帰の終了条件else if(n%2==1) {return (x*modpow(x, n-1))%mod; //nが奇数ならnを1ずらす}else return modpow((x*x)%mod, n/2)%mod; //nが偶数ならnが半分になる}int main(){ll n,m;cin >> n >> m;vector<ll>a(n);for (ll i = 0; i < n; i++){cin >> a[i];}Eratosthenes er(300000);vector<ll>memo(m+1,0);for (ll i = 0; i < n; i++){vector<ll>x=er.divisors(a[i]);for (ll j = 0; j < x.size(); j++){memo[x[j]]+=1;}}vector<ll>ans(m+1,0);for (ll i = m; i >=1; i--){ll y=0;y=modpow(2,memo[i])+mod-1;y%=mod;for (ll j = 2; j*i<=m; j++){y+=mod-ans[j*i];y%=mod;}ans[i]=y;}for (ll i =1; i <=m; i++){cout << ans[i] << endl;}}