문제
https://www.acmicpc.net/problem/24041
24041번: 성싶당 밀키트
첫 번째 줄에 $N, G, K$가 공백으로 구분되어 주어진다. 두 번째 줄부터 $N$ 개의 줄 중 $i$ 번째 줄에는 $i$ 번째 재료에 대한 정보인 부패 속도 $S_i$, 유통기한 $L_i$와 중요한 재료인지를 나타내는
www.acmicpc.net
Algorithm

i에 대한 모든 S_i의 합이 G 이하이므로 가장 큰 x는 2e9이다. x의 최솟값은 0으로 해서 이진탐색으로 x를 찾는다. x일 이후에도 밀키트를 먹을 수 있으면 최솟값을 증가시키고 없다면 최댓값을 감소시키면서 x를 찾는다.
Code
import sys
input = sys.stdin.readline
N, G, K = map(int, input().split())
kits = []
for i in range(N):
s, l, o = map(int, input().split())
kits.append((s, l, o))
left = 0
right = int(2e9)
while True:
if left > right:
break
d = (left + right) // 2
able = True
O_1 = []
O_0 = 0
for s, l, o in kits:
germs = s * max(1, d - l)
if o == 0:
O_0 += germs
if O_0 > G:
able = False
break
if o == 1:
O_1.append(germs)
if not able:
right = d - 1
continue
able = True
O_1.sort(reverse = True)
O_1 = O_1[K :]
exdate = O_0
for o in O_1:
exdate += o
if exdate > G:
right = d - 1
able = False
break
if able:
left = d + 1
print(right)
'Koala - 13기 > 코딩테스트 준비 스터디' 카테고리의 다른 글
[백준 / Python] #2257 화학식량 (0) | 2024.02.10 |
---|---|
[백준/C++] 카드1 (0) | 2024.02.09 |
[백준/C++] 1654번 랜선자르기 (0) | 2024.02.04 |
[C++/백준] 15565번: 귀여운 라이언 (0) | 2024.02.04 |
[백준 / Python] #17390 이건 꼭 풀어야 해! (0) | 2024.02.04 |
문제
https://www.acmicpc.net/problem/24041
24041번: 성싶당 밀키트
첫 번째 줄에 $N, G, K$가 공백으로 구분되어 주어진다. 두 번째 줄부터 $N$ 개의 줄 중 $i$ 번째 줄에는 $i$ 번째 재료에 대한 정보인 부패 속도 $S_i$, 유통기한 $L_i$와 중요한 재료인지를 나타내는
www.acmicpc.net
Algorithm

i에 대한 모든 S_i의 합이 G 이하이므로 가장 큰 x는 2e9이다. x의 최솟값은 0으로 해서 이진탐색으로 x를 찾는다. x일 이후에도 밀키트를 먹을 수 있으면 최솟값을 증가시키고 없다면 최댓값을 감소시키면서 x를 찾는다.
Code
import sys
input = sys.stdin.readline
N, G, K = map(int, input().split())
kits = []
for i in range(N):
s, l, o = map(int, input().split())
kits.append((s, l, o))
left = 0
right = int(2e9)
while True:
if left > right:
break
d = (left + right) // 2
able = True
O_1 = []
O_0 = 0
for s, l, o in kits:
germs = s * max(1, d - l)
if o == 0:
O_0 += germs
if O_0 > G:
able = False
break
if o == 1:
O_1.append(germs)
if not able:
right = d - 1
continue
able = True
O_1.sort(reverse = True)
O_1 = O_1[K :]
exdate = O_0
for o in O_1:
exdate += o
if exdate > G:
right = d - 1
able = False
break
if able:
left = d + 1
print(right)
'Koala - 13기 > 코딩테스트 준비 스터디' 카테고리의 다른 글
[백준 / Python] #2257 화학식량 (0) | 2024.02.10 |
---|---|
[백준/C++] 카드1 (0) | 2024.02.09 |
[백준/C++] 1654번 랜선자르기 (0) | 2024.02.04 |
[C++/백준] 15565번: 귀여운 라이언 (0) | 2024.02.04 |
[백준 / Python] #17390 이건 꼭 풀어야 해! (0) | 2024.02.04 |