結果
| 問題 | No.555 世界史のレポート |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-09-28 06:44:14 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 62 ms / 2,000 ms |
| コード長 | 413 bytes |
| 記録 | |
| コンパイル時間 | 240 ms |
| コンパイル使用メモリ | 85,248 KB |
| 実行使用メモリ | 80,128 KB |
| 最終ジャッジ日時 | 2026-05-28 21:55:01 |
| 合計ジャッジ時間 | 1,983 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge1_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 20 |
ソースコード
N = int(input())
C,V = map(int,input().split())
INF = (1<<30)
dp = [INF]*(N+2)
def f(x):
return min(x,N+1)
dp[1]=0
for i in range(1,N+1):
for j in range(2*i,N+i,i):
dp[f(j)] = min(dp[f(j)],dp[i] + (j-i)//i*V + C)
cnt = 1
j = i
while j<N:
dp[f(2*j)] = min(dp[f(2*j)],dp[i]+cnt*(C+V))
cnt += 1
j *= 2
ans = min(dp[N],dp[N+1])
print(ans)