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
- Sort
- Spring
- 알고리즘
- 자바스크립트
- 스프링핵심원리
- ElasticSearch
- 김영한
- 알고리즘정렬
- 예제로 배우는 스프링 입문
- k8s
- 스프링
- 클린아키텍처
- effectivejava
- 엘라스틱서치
- Effective Java 3
- 이펙티브 자바
- 자바
- java
- 스프링 핵심원리
- Effective Java
- 이차전지관련주
- 카카오
- 오블완
- 스프링부트
- 코딩테스트
- 카카오 면접
- 티스토리챌린지
- kubernetes
- JavaScript
- 이펙티브자바
Archives
- Today
- Total
Kim-Baek 개발자 이야기
힙 정렬 (Heap Sort) 본문
Heap Sort는 Heap 이라는 자료구조를 이용해 정렬을 하는 알고리즘이다.
- Heap 이란 완전 이진 트리 형태로 Paren Node 는 Child Node 보다 반드시 큰(작은) 값을 가진다.
- Heap Sort의 경우 항상 O( N log(N) ) 의 시간복잡도를 가진다.
- 우선 모든 원소를 최대(최소) Heap에 삽입한다.( O(logN) )
- Heap 트리의 최대(최소) 값을 출력한다.( O(1) )
- 최대(최소) 값을 제거하고 Heap을 재배열 한다.( O(logN) )
- Heap이 빌때가지 반복한다.( O(N) )
- Stable 을 만족하지 않는다.
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
vector<int> v = { 3,1,4,1,5,9 };
while(!v.empty()){
//최대힙을 만든다
make_heap(v.begin(), v.end());
//힙의 root를 마지막 원소로 이동시킨다.
pop_heap(v.begin(), v.end());
//마지막 원소를 출력하고 제거한다.
cout << v.back() << ' ';
v.pop_back();
}
return 0;
}
실제로 Heap을 구현 할때는 주로 Array을 이용한다. 이때 index를 1부터 시작했을때,
- Right Child Node의 index 값 : Parent Node의 index 값 * 2
- Left Child Node의 index 값 : Parent Node의 index 값 * 2 + 1
- Parent Node의 index 값 : Child Node의 index 값 / 2
반응형
'컴퓨터 공학 > 자료구조, 알고리즘' 카테고리의 다른 글
tree, heap, binary tree, avl tree, red-black tree (0) | 2020.10.11 |
---|---|
리스트, 스택, 큐 (0) | 2020.10.10 |
퀵 정렬 (Quick Sort) (0) | 2020.09.28 |
병합 정렬 (Merge Sort) (0) | 2020.09.27 |
삽입 정렬 (Insertion Sort) (0) | 2020.09.26 |
Comments