結果
問題 |
No.2693 Sword
|
ユーザー |
👑 |
提出日時 | 2024-02-22 03:51:28 |
言語 | Nim (2.2.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 646 bytes |
コンパイル時間 | 2,229 ms |
コンパイル使用メモリ | 61,804 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-09-29 04:24:28 |
合計ジャッジ時間 | 3,143 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 28 WA * 1 |
ソースコード
import macros;macro ImportExpand(s:untyped):untyped = parseStmt($s[2]) {.checks: off.} import sequtils proc scanf(formatstr: cstring){.header: "<stdio.h>", varargs.} proc ii(): int {.inline.} = scanf("%lld\n", addr result) var n, p, k = ii() var tb = newSeqWith(n, (ii(), ii())) var dp = newSeqWith(k+1, -1) dp[0] = p const mx = 1000_000_000_000_000_000 for (t, b) in tb: var dpn = dp for i in 0..<k: if dp[i] == -1: continue if t == 1: dpn[i+1] = max(dpn[i+1], dp[i] + b) else: dpn[i+1] = max(dpn[i+1], dp[i] * 2) swap(dp, dpn) # must be WA if dp[^1] >= mx: echo -1 quit() echo dp[^1]