結果
| 問題 |
No.1358 [Zelkova 2nd Tune *] 語るなら枚数を...
|
| コンテスト | |
| ユーザー |
brthyyjp
|
| 提出日時 | 2021-01-22 22:39:47 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 688 bytes |
| コンパイル時間 | 933 ms |
| コンパイル使用メモリ | 82,304 KB |
| 実行使用メモリ | 122,880 KB |
| 最終ジャッジ日時 | 2024-12-28 03:41:01 |
| 合計ジャッジ時間 | 15,168 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 1 WA * 12 TLE * 4 |
ソースコード
import sys
import io, os
input = io.BytesIO(os.read(0,os.fstat(0).st_size)).readline
t = int(input())
mod = 10**9+7
def extgcd(a, b):
# ax+by = gcd(x, y)の整数解を求める
# x, y, gcd(a, b)を返す
if b == 0:
return 1, 0, a
q, r = divmod(a, b)
x, y, d = extgcd(b, r)
s, t = y, x-q*y
return s, t, d
for _ in range(t):
n, k, h, y = map(int, input().split())
a0, b0, g = extgcd(n, k)
#print(a0, b0)
ans = 0
for c in range(y//h+1):
if (y-h*c)%g == 0:
p = (y-h*c)//g
cnt = max((p*b0)//n-(-p*a0+k-1)//k+1, 0)
else:
cnt = 0
ans += cnt
ans %= mod
print(ans)
brthyyjp