結果
| 問題 | No.316 もっと刺激的なFizzBuzzをください |
| コンテスト | |
| ユーザー |
kichirb3
|
| 提出日時 | 2018-03-26 00:31:49 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 1,000 ms |
| コード長 | 1,184 bytes |
| 記録 | |
| コンパイル時間 | 624 ms |
| コンパイル使用メモリ | 63,612 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-06-25 06:24:08 |
| 合計ジャッジ時間 | 1,611 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 33 |
ソースコード
// No.316 もっと刺激的なFizzBuzzをください
// https://yukicoder.me/problems/no/316
//
#include <iostream>
using namespace std;
long long int solve(long long int N, long long int a, long long int b, long long int c);
long long int gcd(long long int a, long long int b);
int main() {
std::cin.tie(nullptr);
std::ios::sync_with_stdio(false);
long long N;
cin >> N;
long long a, b, c;
cin >> a >> b >> c;
long long ans = solve(N, a, b, c);
cout << ans << endl;
}
long long int solve(long long int N, long long int a, long long int b, long long int c) {
long long ans = 0;
ans += N / a;
ans += N / b;
ans += N / c;
long long ab = (a * b / gcd(a, b));
long long bc = (b * c / gcd(b, c));
long long ca = (c * a / gcd(c, a));
ans -= N / ab;
ans -= N / bc;
ans -= N / ca;
ans += N / (ab * bc / gcd(ab, bc));
ans += N / (bc * ca / gcd(bc, ca));
ans -= N / (ab * ca / gcd(ab, ca));
return ans;
}
long long int gcd(long long int a, long long int b) {
if (a < b)
swap(a, b);
while (b > 0) {
long long r = a % b;
a = b;
b = r;
}
return a;
}
kichirb3