Algorithm/Baekjoon

[BOJ 2512][백준 2512번] 예산 (파이썬 풀이)

도깨비젤리 2021. 7. 7. 00:18

https://www.acmicpc.net/problem/2512

 

2512번: 예산

첫째 줄에는 지방의 수를 의미하는 정수 N이 주어진다. N은 3 이상 10,000 이하이다. 다음 줄에는 각 지방의 예산요청을 표현하는 N개의 정수가 빈칸을 사이에 두고 주어진다. 이 값들은 모두 1 이상

www.acmicpc.net

🤔 문제 설명 및 입출력


 

 

 접근 방법


목표로 하는 어떠한 값이 있고, 그 값을 찾기 위해서 많은 trial && error 가 있을거 같다??? ➡ 이분탐색을 고려해봐라

 

이분탐색을 사용하기로 결정했으면, 어느 타이밍에 시작값과 끝값을 줄일지를 결정하면 된다.

 

가편성된 예산을 지방의 예산요청과 비교해보고, 가편성 예산이 크다면 원래 값을 국가예산에서 빼고, 지방예산이 크면 가편성된 예산을 국가예산에서 빼주면, 가편성 예산이 목표 예산보다 커져야할지 작아져야할지 알수 있을 거 같다.

 

 이런 논리를 코드로 바꿔보자

 

 

 

👨‍💻 소스 코드


  • 파이썬

 

# 2512번
import sys
input = sys.stdin.readline

N = int(input())
desire_budget_lst = list(map(int, input().split()))
total_budget = int(input())

max_desire = max(desire_budget_lst)


def bin_search(start, end, total_budget):
    while start <= end:
        mid_v = (start+end) // 2
        result = do_satistfiy(mid_v, total_budget)
        # 가예산으로 전부 떡을 치면 --> 좀 더 올려보자
        if result:
            ans = mid_v
            start = mid_v + 1
        # 가예산 편성이 안되면 --> 좀 낮추자
        else:
            end = mid_v - 1
    return ans


def do_satistfiy(mid_v, total_budget):

    for budget in desire_budget_lst:
        total_budget -= mid_v if mid_v <= budget else budget

    # 가측정된 예산으로 모든 도시에 예산 할당이 가능하면 True 반환한다 --> 가측정 예산 키우자
    return True if total_budget >= 0 else False


print(bin_search(0, max_desire, total_budget))

 

 

코드 짜면서 나도 모르게 삼항연산자가 튀어나왔다...이게...골드의 힘????

🔥 강평


이분탐색 연습이 많이 필요하다고 생각해서 계속 이분탐색 문제를 풀고 있는데, 이제 슬슬 문제의 난이도를 높여봐도 괜찮을거 같다.