結果

問題 No.1380 Borderline
ユーザー tobusakanatobusakana
提出日時 2022-12-03 17:14:55
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 42 ms / 2,000 ms
コード長 553 bytes
コンパイル時間 220 ms
コンパイル使用メモリ 82,556 KB
実行使用メモリ 57,856 KB
最終ジャッジ日時 2024-10-10 19:44:38
合計ジャッジ時間 3,558 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 41
権限があれば一括ダウンロードができます

ソースコード

diff #

N,K = map(int,input().split())
P = list(map(int,input().split()))
P = sorted(P, reverse = True)

def is_ok(x): # ボーダーをx点としたときに、合格者数がK以下であればTrue
    passer = 0
    for p in P:
        if p >= x:
            passer += 1
            if passer > K:
                return False
    return True

ng = -1
ok = 401

while abs(ng - ok) > 1:
    mid = abs(ng + ok) // 2
    if is_ok(mid):
        ok = mid
    else:
        ng = mid
        
ans = 0
for p in P:
    if p >= ok:
        ans += 1
        
print(ans)
0