結果
問題 |
No.1430 Coup de Coupon
|
ユーザー |
|
提出日時 | 2021-04-26 13:39:09 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,207 bytes |
コンパイル時間 | 454 ms |
コンパイル使用メモリ | 82,064 KB |
実行使用メモリ | 77,264 KB |
最終ジャッジ日時 | 2024-07-04 22:29:07 |
合計ジャッジ時間 | 3,131 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 11 WA * 16 |
ソースコード
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 len(disc)<=posi+1: pt1=i else: pt1=max(next-disc[posi+1],0) if len(disc_per)<=posi_per+1: pt2=i else: pt2=max(next*(100-disc_per[posi_per+1])//100,0) if pt1<pt2: posi_per+=1 else: posi+=1 print(ans)