티스토리 뷰
어떠한 선택을 연속적으로 하는데,
그 순간순간 가장 좋아보이는 것을 선택하여 솔루션을 만들어 내는 접근법을 Greedy Approach라고 한다.
각각의 선택은 locally optimal하지만 global optimal하지는 않을 수도 있다.
Greedy approach의 장점은 쉽게 알고리즘을 풀어나갈 수 있다는 것이지만,
단점은 항상 optimal 하다는 것을 보장하지 못한다는 것이다.
따라서, 수학적인 증명을 통해 optimal 여부를 판단해야 한다.
일반적으로 이 접근법은 세가지 절차로 나눌 수 있다.
1. Selection Procedure
어떠한 기준(Greedy Criteria)을 가지고 선택한다.
2. Feasibility Check
새롭게 선택한 것이 해를 만드는데 있어서 적합한지 판단한다.
3. Solution Check
만들어진 인스턴스의 set이 해를 만들어내는지 판단한다.
이 알고리즘 접근법을 사용하는 대표적인 예로 Minimum spanning tree 구하는 알고리즘(Prim, Kruskal), 허프만 코드(Huffman Code) 생성 알고리즘 등등이 있다.
'Computer Science' 카테고리의 다른 글
[Algorithms] Backtracking (0) | 2011.07.07 |
---|---|
[Algorithms] Minimum spanning tree 알고리즘 (0) | 2011.07.07 |
[Algorithms] NP 이론(NP theory) (0) | 2011.07.07 |
[Algorithms] stable sort와 unstable sort(Merge vs Quick) (0) | 2011.07.05 |
[Algorithms] Dynamic Programming (0) | 2011.07.05 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- java
- 자료구조
- 카타르 음주
- reversing
- 개발
- 리버싱
- 머신러닝
- 자바
- 리버스엔지니어링
- Data Structure
- 알고리즘
- Discrete Mathematics
- 데이터 과학
- 대학원
- 통계학습
- 이산수학
- Machine Learning
- 리눅스
- 운영체제
- operating systems
- statistical learning
- 기계학습
- Reverse Engineering
- 데이터 사이언스
- 안드로이드
- android
- Algorithms
- linux
- Data Science
- 카타르
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함