제출 #1126247

#제출 시각아이디문제언어결과실행 시간메모리
1126247MuhammetBrunhilda’s Birthday (BOI13_brunhilda)C++20
100 / 100
255 ms79272 KiB
#include <bits/stdc++.h> using namespace std; const int M = 1e7; int n, q, a[100005], b[M+1], dp[M+1]; int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); cin >> n >> q; long long s = 1; for(int i = 1; i <= n; i++){ cin >> a[i]; for(int j = a[i]-1; j <= M; j += a[i]){ b[j] = max(b[j], a[i]-1); } b[M] = max(b[M], M%a[i]); if(s > 1e7) continue; s *= a[i]; } for(int i = M-1; i >= 1; i--){ b[i] = max(b[i], b[i+1]-1); } dp[0] = 0; for(int i = 1; i <= M; i++){ dp[i] = dp[i-b[i]] + 1; } while(q--){ int x; cin >> x; if(x >= s) cout << "oo\n"; else cout << dp[x] << "\n"; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...