1114 - 통나무 자르기

LeeKyoungChang·2022년 5월 14일
0

Algorithm

목록 보기
115/203
post-thumbnail

📚 1114 - 통나무 자르기

통나무 자르기

 

이해

아무래도, 그리디 골드1문제는 생각보다 많이 어려운 것 같다.

설명이 잘되어 있는 곳

이를 참고하였다.

 

소스

import sys  
  
read = sys.stdin.readline  
  
L, K, C = map(int, read().split())  
cuts = [0, L] + list(map(int, read().split()))  
cuts.sort()  
  
def solution(x):  
    cnt = 0  
    cut_start = L  
    prev = []  
    first = 0  
  
    # x라는 길이를 넘으면 자른다.  
    for i in range(len(cuts)-1, -1, -1):  
        diff = cuts[i] - cuts[i-1]  
        total = cut_start - cuts[i]  
        print("i : ", i , " cur_start", cut_start, "cuts : ", cuts, "total : ", total, " x: ", x, " diff : ", diff)  
        if diff > x:  
            # 이분탐색, 오른쪽  
            return 10001, 0  
        elif total > x:  
            # i번째 자르고, i+1을 저장  
            cut_start = cuts[i+1]  
            prev.append(cuts[i+1])  
            cnt += 1  
        else:  
            continue  
  
    if cnt < C:  
        first = cuts[1]  
    else:  
        # 인덱스 뒤에서부터 삽입되니, 마지막으로 추가된 것이 first 값이 된다.  
        first = prev[-1]  
  
    return cnt, first  
  
lo = 0  
hi = L  
answer = 0  
first_cut = 0  
while lo <= hi:  
    mid = (lo+hi) // 2  
  
    cnt, first = solution(mid)  
  
    if C < cnt:  
        lo = mid + 1  
    else:  
        answer = mid  
        first_cut = first  
        hi = mid - 1  
  
print(answer, first_cut)

 

profile
"야, (오류 만났어?) 너두 (해결) 할 수 있어"

0개의 댓글