結果
問題 |
No.2682 Visible Divisible
|
ユーザー |
|
提出日時 | 2024-03-20 21:18:02 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 611 bytes |
コンパイル時間 | 4,396 ms |
コンパイル使用メモリ | 257,752 KB |
最終ジャッジ日時 | 2025-02-20 08:34:37 |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 7 WA * 7 |
ソースコード
#include <bits/stdc++.h> #include <atcoder/all> using namespace std; using ll = long long; #define rep(i,n) for(ll i=0;i<(ll)(n);i++) using mint = atcoder::modint998244353; // divide map<ll,ll> dv(ll x){ map<ll,ll> rt; for(ll i=2;i*i<=x;i++){ while(x%i==0){ rt[i]++; x/=i; } } if(x!=1) rt[x]++; return rt; } int main(){ int n,k; cin>>n>>k; vector<int> a(n); rep(i,n) cin>>a.at(i); auto dvk=dv(k); rep(i,n){ auto dva=dv(a.at(i)); for(auto [p,c]:dva){ if(dvk.count(p)){ if(dvk.at(p)<=c){ dvk.erase(p); } } } } if(dvk.empty()) cout<<"Yes\n"; else cout<<"No\n"; }