結果
| 問題 | 
                            No.864 四方演算
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2022-05-24 14:24:35 | 
| 言語 | PyPy3  (7.3.15)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 54 ms / 1,000 ms | 
| コード長 | 582 bytes | 
| コンパイル時間 | 160 ms | 
| コンパイル使用メモリ | 81,920 KB | 
| 実行使用メモリ | 59,392 KB | 
| 最終ジャッジ日時 | 2024-09-20 14:23:10 | 
| 合計ジャッジ時間 | 2,479 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 27 | 
ソースコード
def divisors(n: int) -> list:
    divisor = []
    for i in range(1, int(n ** 0.5) + 1):
        if n % i == 0:
            divisor.append(i)
            if i != n // i:
                divisor.append(n // i)
    divisor.sort()
    return divisor
n = int(input())
k = int(input())
div = divisors(k)
ans = 0
for ac in div:
    bd = k // ac
    
    if ac > 2 * n or bd > 2 * n:
        continue
    if ac <= n + 1:
        ac -= 1
    else:
        ac = 2 * n - ac + 1
    if bd <= n + 1:
        bd -= 1
    else:
        bd = 2 * n - bd + 1
    
    ans += ac * bd
print(ans)