Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- Kotlin
- spring cloud
- spring oauth
- 백준 15685
- 백준 16235
- spring security
- JPA
- 백준 16719
- MSA
- 백준 파이썬
- 프로래머스
- sql 기술면접
- Spring
- 파이썬
- 백준 19238
- 백준
- 백준 17626
- 웹어플리케이션 서버
- 백준 16236
- springboot
- JVM
- java 기술면접
- Spring Boot
- 백준 17779
- MySQL
- java
- Coroutine
- with recursive
- 프로그래머스
- re.split
Archives
- Today
- Total
시작이 반
[백준] 2805번번 (python 파이썬) 본문
SMALL
나무를 0미터를 가져갈 수 도있고 최대 높이를 가져갈 수도있다.
즉 절단기의 길이는
최대 높이를 자르려면 맨 밑동을 잘라야한다 -> 0
0미터를 가져간다면 가장큰 높이의 나무만큼 절단기 높이를 설정한다 -> max(trees)
n, m = map(int, input().split(' '))
trees = list(map(int, input().split(' ')))
def binary():
left = 0
right = max(trees)
while left <= right:
mid = (left + right) // 2
height = 0
for tree in trees:
if tree - mid > 0:
height += tree - mid
if height >= m: # 잘린 길이가 구하려는 것보다 크면 더 큰높이로 자르기
left = mid + 1
elif height < m: # 잘린 길이가 구하려는 것보다 작으면 더 작은 높이로 자르기
right = mid - 1
return right
print(binary())
LIST
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 1753번번 (python 파이썬) (1) | 2021.03.20 |
---|---|
[백준] 2110번번 (python 파이썬) (0) | 2021.03.17 |
[백준] 10816번번 (python 파이썬) (0) | 2021.03.16 |
[백준] 1920번 (python 파이썬) (0) | 2021.03.16 |
[백준] 1629번 (python 파이썬) (0) | 2021.03.15 |