結果
問題 |
No.1457 ツブ消ししとるなHard
|
ユーザー |
|
提出日時 | 2021-03-31 21:22:21 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,175 bytes |
コンパイル時間 | 140 ms |
コンパイル使用メモリ | 82,424 KB |
実行使用メモリ | 130,432 KB |
最終ジャッジ日時 | 2024-12-15 14:26:02 |
合計ジャッジ時間 | 13,751 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 13 TLE * 4 |
ソースコード
import sys input = sys.stdin.readline from collections import * N, M, X, Y, Z = map(int, input().split()) A = list(map(int, input().split())) cnt = 0 for i in range(N): if A[i]>=X: cnt += 1 if cnt>M: print('Handicapped') exit() B = [] already_v, already_c = 0, 0 for i in range(N): if A[i]>=X: already_v += A[i] already_c += 1 elif A[i]>Y: B.append(A[i]) n = len(B) n1 = n//2 n2 = n-n//2 d = defaultdict(lambda: defaultdict(int)) for S in range(1<<n1): v, c = 0, 0 for i in range(n1): if (S>>i)&1: if B[i]>Y: v += B[i] c += 1 else: if B[i]>=X: v += B[i] c += 1 d[c][v] += 1 ans = 0 for S in range(1<<n2): v, c = 0, 0 for i in range(n2): if (S>>i)&1: if B[n1+i]>Y: v += B[n1+i] c += 1 else: if B[n1+i]>=X: v += B[n1+i] c += 1 for i in range(n1+1): if c+i+already_c>0 and c+i+already_c<=M: ans += d[i][(c+i+already_c)*Z-v-already_v] print(ans)