結果
問題 |
No.371 ぼく悪いプライムじゃないよ
|
ユーザー |
|
提出日時 | 2016-03-03 14:55:22 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 991 bytes |
コンパイル時間 | 775 ms |
コンパイル使用メモリ | 65,888 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-24 13:45:44 |
合計ジャッジ時間 | 2,028 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 40 WA * 2 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:30:25: warning: ‘maxpf’ may be used uninitialized in this function [-Wmaybe-uninitialized] 30 | if (0<=maxi && n<maxpf) | ~^~~~~~
ソースコード
#include <iostream> #include <algorithm> #include <vector> #include <cstdio> #include <cmath> using namespace std; typedef long long int llint; // 最小の素因数を求める。u>=3 llint pfactor(llint u){ if (u%2==0) return 2ll; for (llint i=3ll;i*i<=u;i+=2ll) if (u%i==0) return i; return u; } int main(){ llint n,i,t; llint l,h,hq; llint maxpf,maxi=-1; cin>>l>>h; hq=ceil(sqrt(h)); for (n=hq;2ll<=n;n--){ if (h/n*n<l || pfactor(n)!=n) continue; if (0<=maxi && n<maxpf) break; for (i=h/n;n<=i;i--){ if (i*n<l) break; if ((0<=maxi || n!=maxpf) && pfactor(i)==i){ cout<<(i*n)<<endl; exit(0); } t=pfactor(i*n); if (0<=maxi || (maxpf<t || (maxpf==t && maxi<i*n) )){ maxi=i*n; maxpf=t; } } } cout<<maxi<<endl; return 0; }