結果
問題 | No.316 もっと刺激的なFizzBuzzをください |
ユーザー |
![]() |
提出日時 | 2015-12-26 19:29:30 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 1,000 ms |
コード長 | 897 bytes |
コンパイル時間 | 592 ms |
コンパイル使用メモリ | 70,056 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-11-21 12:13:58 |
合計ジャッジ時間 | 1,489 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 33 |
ソースコード
#include <iostream> #include <vector> #include <string> #include <algorithm> #include <map> #include <set> #include <cstdio> #include <cmath> #define rep(i,l,n) for(int i=l;i<n;i++) #define rer(i,l,n) for(int i=l;i<=n;i++) #define all(a) a.begin(),a.end() #define o(a) cout<<a<<endl #define pb(a) push_back(a) #define mk(a,b) make_pair(a,b) #define fi first #define se second using namespace std; typedef long long lint; typedef vector<int> vi; typedef vector<vi> vvi; typedef pair<int,int> pii; lint gcd(lint a,lint b){ if(b==0) return a; return gcd(b,a%b); } int main(){ lint a,b,c,n,ans=0,lca,lab,lbc,labc; cin>>n>>a>>b>>c; lca=c*a/gcd(c,a); lab=a*b/gcd(a,b); lbc=b*c/gcd(b,c); labc=lab*c/gcd(lab,c); //o(lab<<" "<<lbc<<" "<<lca<<" "<<labc); if(a==b && b==c){ ans=n/a; }else if(a==b||b==c){ ans=n/a+n/c-n/lca; }else{ ans=n/a+n/b+n/c-n/lab-n/lbc-n/lca+n/labc; } o(ans); }