結果

問題 No.2125 Inverse Sum
ユーザー pitP
提出日時 2022-11-18 21:45:21
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 668 bytes
コンパイル時間 143 ms
コンパイル使用メモリ 82,488 KB
実行使用メモリ 60,412 KB
最終ジャッジ日時 2024-09-20 02:07:41
合計ジャッジ時間 2,374 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 18 WA * 12
権限があれば一括ダウンロードができます

ソースコード

diff #

from math import gcd,ceil,sqrt
p,q = map(int,input().split())
g = gcd(p,q)
p //= g
q //= g

if p/q > 2:
    print(0)
elif p//q == 2:
    print(1)
    print(1,1)
elif p == q + 1:
    ans = set()
    ans.add((1,q))
    ans.add((q,1))
    print(len(ans))
    for (n,m) in ans:
        print(n,m)
elif p == q:
    print(1)
    print(2,2)
elif p/q < 1:
    nm = []
    for n in range(1,ceil(sqrt(q))+1):
        if (p*n-q > 0) and ((q*n)%(p*n-q) == 0):
            nm.append((n,(q*n)//(p*n-q)))
    ans = set()
    for (n,m) in nm:
        ans.add((n,m))
        ans.add((m,n))
    ans = list(ans)
    ans.sort()
    print(len(ans))
    for (n,m) in ans:
        print(n,m)
0