結果
問題 | No.1611 Minimum Multiple with Double Divisors |
ユーザー |
![]() |
提出日時 | 2021-07-21 21:40:49 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 724 bytes |
コンパイル時間 | 1,563 ms |
コンパイル使用メモリ | 169,380 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-17 16:59:25 |
合計ジャッジ時間 | 7,692 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 9 WA * 28 |
ソースコード
#include <bits/stdc++.h> using namespace std; #define ll long long #define rep(i,n) for(int (i)=0;(i)<(n);(i)++) #define Pr pair<ll,ll> #define Tp tuple<ll,ll,ll> using Graph = vector<vector<int>>; const ll mod = 1000000007; int main() { ll T; cin >>T; vector<ll> pr = {2,3,5,7,11,13,17,19,23,29,31,37,41}; rep(ii,T){ ll N; cin >> N; ll ans = 2e9; rep(i,13){ ll K = N; ll b = pr[i]; while(K%pr[i]==0){ K /= pr[i]; b *= pr[i]; if(b>100000){ b = 2e9; break; } } ans = min(ans,b); } cout << N*ans << endl; } //cout << ans << endl; }