結果
問題 |
No.2227 King Kraken's Attack
|
ユーザー |
![]() |
提出日時 | 2023-03-01 06:57:41 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 640 ms / 2,000 ms |
コード長 | 1,429 bytes |
コンパイル時間 | 403 ms |
コンパイル使用メモリ | 82,512 KB |
実行使用メモリ | 75,520 KB |
最終ジャッジ日時 | 2024-10-02 11:40:04 |
合計ジャッジ時間 | 5,945 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 42 |
ソースコード
H,W,LA,LB,KA,KB=map(int,input().split()) if KA==0 and KB==0: print((H+LA-1)//LA+(W+LB-1)//LB) exit() ANS=10**9 for yoko in range((H+LA-1)//LA+1): teki=H*W yoko_damage=W*min(H,yoko*LA) no_damage=teki-yoko_damage if no_damage>=KA*yoko: no_damage-=KA*yoko else: yoko_damage-=KA*yoko-no_damage no_damage=0 #print(yoko,yoko_damage,no_damage) if yoko_damage<=0 and no_damage<=0: ANS=min(ANS,yoko) continue NG=0 OK=10**9 while OK>NG+1: mid=(OK+NG)//2 rest=max(0,yoko_damage-min(W,mid*LB)*min(H,yoko*LA))+no_damage if mid*KB>=rest: OK=mid else: NG=mid #print(yoko,OK) ANS=min(ANS,yoko+OK) H,W=W,H LA,LB=LB,LA KA,KB=KB,KA for yoko in range((H+LA-1)//LA+1): teki=H*W yoko_damage=W*min(H,yoko*LA) no_damage=teki-yoko_damage if no_damage>=KA*yoko: no_damage-=KA*yoko else: yoko_damage-=KA*yoko-no_damage no_damage=0 #print(yoko,yoko_damage,no_damage) if yoko_damage<=0 and no_damage<=0: ANS=min(ANS,yoko) continue NG=0 OK=10**9 while OK>NG+1: mid=(OK+NG)//2 rest=max(0,yoko_damage-min(W,mid*LB)*min(H,yoko*LA))+no_damage if mid*KB>=rest: OK=mid else: NG=mid #print(yoko,OK) ANS=min(ANS,yoko+OK) print(ANS)