초보개발자

[FENCE] 울타리 잘라내기 본문

알고리즘/문제해결 소스코드

[FENCE] 울타리 잘라내기

___yejin 2017. 7. 4. 15:10
  • 입력: 테스트케이스 C(C≤50), 판자의 수(1≤N≤20,000), hi(0≤hi≤10,000)
  • 출력: 주어진 울타리에서 잘라낼 수 있는 최대 직사각형의 크기
  • 알고리즘: 세그먼트 트리, 분할정복
  • 소스코드
    tree에 각 구간의 가장 낮은 높이를 가지는 인덱스를 저장한 뒤, 최대 직사각형의 크기를 구한다. 크기를 구할 때 각 구간의 가장 낮은 높이의 인덱스를 받고, 해당 인덱스를 제외하고서 양 구간의 직사각형의 크기를 재귀로 구한다.
  • 참고: https://algospot.com/judge/problem/read/FENCE
  • Baekjoon에서 6549번 문제와 입력만 다를 뿐 완전히 같은 문제로, 전에 풀었던 코드를 전혀 보지 않고 풀려고 풀었다. 단점이자 장점이 단기기억력이 좋다는건데 안 보고 구현했음에도 불구하고 굉장히 유사한 코드로 구현이 됐다.


'알고리즘 > 문제해결 소스코드' 카테고리의 다른 글

[2805] 나무 자르기  (0) 2017.07.25
[2178] 미로 탐색  (0) 2017.07.20
[ORDERING] 할 일 순서 정하기  (0) 2017.04.06
[LAN] 근거리 네트워크  (0) 2017.03.02
[TRAVERSAL] 트리 순회 순서 변경  (0) 2017.02.21
Comments