結果
| 問題 |
No.2280 FizzBuzz Difference
|
| コンテスト | |
| ユーザー |
miscalc
|
| 提出日時 | 2023-04-18 02:08:28 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 46 ms / 2,000 ms |
| コード長 | 1,048 bytes |
| コンパイル時間 | 2,015 ms |
| コンパイル使用メモリ | 199,996 KB |
| 最終ジャッジ日時 | 2025-02-12 09:49:40 |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 7 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#include <atcoder/math>
using namespace atcoder;
// M 以下の正の整数のうち、A で割ったあまりが C となるものの個数
ll f(ll M, ll A, ll C)
{
if (C != 0)
M += A - C;
return M / A;
}
ll solve(ll M, ll A, ll B, ll K)
{
ll g = gcd(A, B);
if (K % g != 0)
return 0;
M /= g, A /= g, B /= g, K /= g;
if (K > A)
return 0;
else if (K == A)
{
ll cnt_A = f(M, A, 0), cnt_B = f(M, B, 0), cnt_AB = f(M, A * B, 0);
ll N = cnt_A + cnt_B - cnt_AB;
ll cnt_notA = cnt_B - cnt_AB;
ll X_N = max(M / A * A, M / B * B);
if (X_N % A == 0)
return (N - 1) - (2 * cnt_notA);
else
return (N - 1) - (2 * cnt_notA - 1);
}
else
{
ll Y = crt({0, -K}, {A, B}).first;
ll Z = crt({-K, 0}, {A, B}).first;
return f(M - K, A * B, Y) + f(M - K, A * B, Z);
}
}
int main()
{
int T;
cin >> T;
while (T--)
{
ll M, A, B, K;
cin >> M >> A >> B >> K;
cout << solve(M, A, B, K) << endl;
}
}
miscalc