일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 나무자르기
- VituralBox
- 세그먼트 트리
- 연속합
- 쉬운 계단 수
- 축사 배정
- 이분매칭
- Flpyd-Warshall
- Floyd-Warshall
- 동적계획법
- 피보나치수열
- Mysql5.7
- 백준
- 백트래킹
- Ubuntu64bit
- tensorflow
- SpringBoot
- 알고리즘
- 이분탐색
- pythonanywhere
- 코드그라운드
- 피노나치 수열
- 이분 매칭
- 최소스패닝트리
- 알고스팟
- 최소신장트리
- 네이버 지도 api
- 이친수
- 분할정복
- 다이나믹 프로그래밍
Archives
- Today
- Total
초보개발자
[FENCE] 울타리 잘라내기 본문
- 입력: 테스트케이스 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