結果
問題 | No.316 もっと刺激的なFizzBuzzをください |
ユーザー |
|
提出日時 | 2018-09-12 10:16:54 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 1,000 ms |
コード長 | 744 bytes |
コンパイル時間 | 443 ms |
コンパイル使用メモリ | 54,388 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-26 08:22:59 |
合計ジャッジ時間 | 1,592 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 33 |
ソースコード
#include <iostream> typedef long long dlong; dlong gcd(dlong a, dlong b) { if (a < b) { dlong tmp = b; b = a; a = tmp; } while (true) { dlong mod = a % b; if (mod == 0) break; a = b; b = mod; } return b; } dlong lcm(dlong a, dlong b) { return a * b / gcd(a, b); } int main(int argc, char const* argv[]) { dlong n; std::cin >> n; dlong a, b, c; std::cin >> a >> b >> c; dlong gcd_ab = lcm(a, b); dlong gcd_bc = lcm(b, c); dlong gcd_ca = lcm(c, a); dlong gcd_abc = lcm(gcd_ab, c); dlong ans = n /a + n / b + n / c - n /gcd_ab - n /gcd_bc - n / gcd_ca + n / gcd_abc; std::cout << ans << std::endl; return 0; }