結果
問題 | No.1606 Stuffed Animals Keeper |
ユーザー |
👑 ![]() |
提出日時 | 2021-04-16 01:35:17 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 1,977 ms / 3,000 ms |
コード長 | 1,061 bytes |
コンパイル時間 | 104 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 11,008 KB |
最終ジャッジ日時 | 2024-07-06 07:51:05 |
合計ジャッジ時間 | 24,966 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 48 |
ソースコード
"""python テスト用提出"""import sysfrom sys import stdinN = int(stdin.readline())A = list(map(int,stdin.readline().split()))#制約チェックassert 2 <= N <= 5000assert len(A) == Nfor i in A:assert 0 <= i <= 2lis = [] #2で区切られた各区間に関して (0の数,1の数) を入れていくallzero = 0 #0の総数allone = 0 #1の総数zero = 0one = 0for i in A:if i == 0:zero += 1allzero += 1elif i == 1:one += 1allone += 1elif zero + one > 0:lis.append( (zero,one) )zero = 0one = 0if zero + one > 0:lis.append( (zero,one) )M = allzero + allone#ちょうど allzero 個入る区間の組み合わせのうち、#oneの数の総和が最小の区間の組み合わせを求めればよいdp = [float("inf")] * (allzero + 1)dp[0] = 0for nz,no in lis:for i in range(allzero-(nz+no),-1,-1):dp[i + (nz+no)] = min(dp[i + (nz+no)] , dp[i] + no)if dp[-1] == float("inf"):print (-1)else:print (dp[-1])