結果
問題 | No.2232 Miser's Gift |
ユーザー | McGregorsh |
提出日時 | 2023-03-17 00:53:14 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 427 ms / 2,000 ms |
コード長 | 1,739 bytes |
コンパイル時間 | 302 ms |
コンパイル使用メモリ | 82,064 KB |
実行使用メモリ | 168,976 KB |
最終ジャッジ日時 | 2024-09-18 09:41:06 |
合計ジャッジ時間 | 19,776 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 143 ms
89,256 KB |
testcase_01 | AC | 147 ms
89,456 KB |
testcase_02 | AC | 144 ms
89,540 KB |
testcase_03 | AC | 357 ms
168,280 KB |
testcase_04 | AC | 407 ms
168,728 KB |
testcase_05 | AC | 172 ms
90,000 KB |
testcase_06 | AC | 147 ms
89,076 KB |
testcase_07 | AC | 169 ms
91,004 KB |
testcase_08 | AC | 384 ms
168,748 KB |
testcase_09 | AC | 396 ms
168,296 KB |
testcase_10 | AC | 384 ms
168,736 KB |
testcase_11 | AC | 379 ms
168,496 KB |
testcase_12 | AC | 379 ms
168,400 KB |
testcase_13 | AC | 350 ms
168,412 KB |
testcase_14 | AC | 357 ms
168,340 KB |
testcase_15 | AC | 352 ms
168,636 KB |
testcase_16 | AC | 350 ms
168,312 KB |
testcase_17 | AC | 352 ms
168,424 KB |
testcase_18 | AC | 357 ms
168,484 KB |
testcase_19 | AC | 353 ms
168,480 KB |
testcase_20 | AC | 355 ms
168,376 KB |
testcase_21 | AC | 361 ms
168,296 KB |
testcase_22 | AC | 358 ms
168,960 KB |
testcase_23 | AC | 418 ms
168,776 KB |
testcase_24 | AC | 418 ms
168,700 KB |
testcase_25 | AC | 422 ms
168,384 KB |
testcase_26 | AC | 427 ms
168,976 KB |
testcase_27 | AC | 424 ms
168,676 KB |
testcase_28 | AC | 399 ms
168,528 KB |
testcase_29 | AC | 399 ms
168,196 KB |
testcase_30 | AC | 395 ms
168,644 KB |
testcase_31 | AC | 404 ms
168,712 KB |
testcase_32 | AC | 399 ms
168,768 KB |
testcase_33 | AC | 361 ms
168,716 KB |
testcase_34 | AC | 360 ms
168,768 KB |
testcase_35 | AC | 361 ms
168,656 KB |
testcase_36 | AC | 364 ms
168,420 KB |
testcase_37 | AC | 361 ms
168,624 KB |
testcase_38 | AC | 162 ms
90,088 KB |
testcase_39 | AC | 164 ms
89,444 KB |
testcase_40 | AC | 164 ms
89,508 KB |
testcase_41 | AC | 164 ms
89,596 KB |
testcase_42 | AC | 161 ms
89,888 KB |
testcase_43 | AC | 166 ms
89,436 KB |
testcase_44 | AC | 167 ms
89,880 KB |
testcase_45 | AC | 164 ms
89,776 KB |
testcase_46 | AC | 163 ms
89,392 KB |
testcase_47 | AC | 163 ms
89,448 KB |
testcase_48 | AC | 155 ms
89,372 KB |
testcase_49 | AC | 153 ms
89,484 KB |
testcase_50 | AC | 155 ms
89,368 KB |
testcase_51 | AC | 155 ms
89,460 KB |
testcase_52 | AC | 156 ms
89,552 KB |
testcase_53 | AC | 153 ms
89,680 KB |
testcase_54 | AC | 156 ms
89,508 KB |
testcase_55 | AC | 158 ms
89,504 KB |
testcase_56 | AC | 158 ms
89,664 KB |
testcase_57 | AC | 157 ms
89,656 KB |
ソースコード
import sys, re from fractions import Fraction from math import ceil, floor, sqrt, pi, factorial, gcd from copy import deepcopy from collections import Counter, deque, defaultdict from heapq import heapify, heappop, heappush from itertools import accumulate, product, combinations, combinations_with_replacement, permutations from bisect import bisect, bisect_left, bisect_right from functools import reduce from decimal import Decimal, getcontext, ROUND_HALF_UP def i_input(): return int(input()) def i_map(): return map(int, input().split()) def i_list(): return list(i_map()) def i_row(N): return [i_input() for _ in range(N)] def i_row_list(N): return [i_list() for _ in range(N)] def s_input(): return input() def s_map(): return input().split() def s_list(): return list(s_map()) def s_row(N): return [s_input for _ in range(N)] def s_row_str(N): return [s_list() for _ in range(N)] def s_row_list(N): return [list(s_input()) for _ in range(N)] def lcm(a, b): return a * b // gcd(a, b) def get_distance(x1, y1, x2, y2): d = sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2) return d def rotate(table): n_fild = [] for x in zip(*table[::-1]): n_fild.append(x) return n_fild sys.setrecursionlimit(10 ** 7) INF = float('inf') MOD = 10 ** 9 + 7 MOD2 = 998244353 def main(): N, W = i_map() nums = [i_list() for i in range(N)] dp = [[0] * (W+1) for i in range(N+1)] dp[0][0] = 0 for i in range(N): w, v = nums[i] for j in range(W+1): if j + w <= W: dp[i+1][j+w] = max(dp[i+1][j+w], dp[i][j]+v) dp[i+1][j] = max(dp[i+1][j], dp[i][j]) for i in range(W-1, -1, -1): print(dp[N][-1] - dp[N][i] + 1) if __name__ == '__main__': main()