結果
問題 | No.67 よくある棒を切る問題 (1) |
ユーザー |
![]() |
提出日時 | 2022-06-21 03:31:20 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 738 bytes |
コンパイル時間 | 311 ms |
コンパイル使用メモリ | 82,680 KB |
実行使用メモリ | 113,596 KB |
最終ジャッジ日時 | 2025-03-03 12:00:17 |
合計ジャッジ時間 | 16,724 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 16 TLE * 1 -- * 13 |
ソースコード
def Bisect_Int(ok,ng,is_ok): while abs(ok-ng)>1: mid=(ok+ng)//2 if is_ok(mid): ok=mid else: ng=mid return ok def Bisect_Float(ok,ng,is_ok,eps=1e-12,cnt=0): if cnt: for _ in range(cnt): mid=(ok*ng)/2 if is_ok(mid): ok=mid else: ng=mid else: while abs(ok-ng)>eps: mid=(ok+ng)/2 if is_ok(mid): ok=mid else: ng=mid return ok N=int(input()) L=list(map(int,input().split())) K=int(input()) def is_ok(x): cnt=0 for l in L: cnt+=l//x return cnt>=K ans=Bisect_Float(1e-9,max(L),is_ok,eps=1e-9) print(ans)