結果
問題 |
No.1430 Coup de Coupon
|
ユーザー |
|
提出日時 | 2021-04-26 13:34:42 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 1,003 bytes |
コンパイル時間 | 186 ms |
コンパイル使用メモリ | 82,608 KB |
実行使用メモリ | 77,312 KB |
最終ジャッジ日時 | 2024-07-04 22:22:59 |
合計ジャッジ時間 | 3,086 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 11 WA * 14 RE * 2 |
ソースコード
N,C=map(int,input().split()) P=[int(input()) for i in range(N)] disc=[] disc_per=[] P.sort(reverse=True) for i in range(C): t,x=map(int,input().split()) if t==1: disc.append(x) else: disc_per.append(x) disc_per.sort(reverse=True) disc.sort(reverse=True) posi,posi_per=0,0 ans=0 for j,i in enumerate(P): if len(disc)<=posi and len(disc_per)<=posi_per: ans+=i continue if len(disc)<=posi: pt1=i else: pt1=max(i-disc[posi],0) if len(disc_per)<=posi_per: pt2=i else: pt2=max(i*(100-disc_per[posi_per])//100,0) if pt1>pt2: posi_per+=1 ans+=pt2 elif pt2>pt1: posi+=1 ans+=pt1 else: if j==len(P)-1: ans+=pt1 break else: ans+=pt1 next=P[j+1] if max(next-disc[posi+1],0)<max(next*(100-disc_per[posi_per+1])//100,0): posi_per+=1 else: posi+=1 print(ans)