結果

問題 No.2693 Sword
ユーザー 👑 seekworser
提出日時 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
権限があれば一括ダウンロードができます

ソースコード

diff #

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]
0