結果
問題 |
No.2693 Sword
|
ユーザー |
![]() |
提出日時 | 2024-03-22 21:33:16 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 595 bytes |
コンパイル時間 | 334 ms |
コンパイル使用メモリ | 81,920 KB |
実行使用メモリ | 61,568 KB |
最終ジャッジ日時 | 2024-09-30 10:58:09 |
合計ジャッジ時間 | 2,340 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 WA * 2 |
other | AC * 16 WA * 13 |
ソースコード
N,P,K=map(int,input().split()) L1=[] L2=[] for i in range(N): t,b=map(int,input().split()) if t==1: L1.append(b) else: L2.append(2) L1.sort(reverse=True) L2.sort(reverse=True) u=[1] for i in range(len(L2)): u.append(L2[i]) result=0 for j in range(1,K+1): if j>=len(u): break u[j]=u[j-1]*u[j] if u[j]>10**18: print(-1) exit() result=0 for i in range(len(L1)): if i>0: P+=L1[i-1] rest=K-i if rest<0: break if rest<len(u): score=P*u[rest] else: score=P*u[-1] result=max(result,score) if result<=10**18: print(result) else: print(-1)