結果

問題 No.2891 Mint
ユーザー adapchi
提出日時 2024-09-13 21:58:39
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 130 ms / 2,000 ms
コード長 452 bytes
コンパイル時間 375 ms
コンパイル使用メモリ 82,024 KB
実行使用メモリ 75,648 KB
最終ジャッジ日時 2024-09-13 21:58:48
合計ジャッジ時間 6,172 ms
ジャッジサーバーID
(参考情報)
judge4 / judge6
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 54
権限があれば一括ダウンロードができます

ソースコード

diff #

# M mod k = M - k * (M // k)

N, M = map(int, input().split())

# i <= M // k < i + 1
# M / (i + 1) < k <= M / i
# ceil((M + 1) / (i + 1)) <= k <= floor(M / i)

ans = 0

k = 1
while M // k > k:
  if k <= N:
    ans += M - k * (M // k)
  k += 1

for i in range(0, M // k + 1):
  l = min(N + 1, (M + 1 + i) // (i + 1))
  r = min(N + 1, M // i + 1) if i >= 1 else N + 1
  ans += M * (r - l) - (r - l) * (l + r - 1) // 2 * i
  
print(ans % 998244353)
  
  
0