[자료구조] 힙(Heap)

2023. 7. 19. 11:27·CS 지식/[자료구조]
목차
  1. 우선순위 큐
  2. 힙(Heap)
  3. 힙 종류
  4. 1) 최대 힙(max heap)
  5. 2) 최소 힙(min heap)
  6. 구현
  7. 부모 노드와 자식 노드 관계
  8. 힙의 삽입
  9. 힙의 삭제

우선순위 큐

  • 우선순위의 개념을 큐에 도입한 자료구조
  • 데이터들이 우선순위를 가지고 있음
  • 우선순위가 높은 데이터가 먼저 나감
  • 스택은 LIFO, 큐는 FIFO
  • 배열, 연결 리스트, 힙으로 구현
  • 힙 → 삽입 : O(logn), 삭제 : O(logn)

 


힙(Heap)

  • 완전 이진 트리의 일종
  • 여러 값 중 최대값과 최소값을 빠르게 찾아내도록 만들어진 자료구조
  • 반정렬 상태
  • 힙 트리는 중복된 값 허용(이진 탐색 트리는 중복값 허용 X)

힙 종류

1) 최대 힙(max heap)

  • 부모 노드의 키 값이 자식 노드의 키 값보다 크거나 같은 완전 이진 트리

2) 최소 힙(min heap)

  • 부모 노드의 키 값이 자식 노드의 키 값보다 작거나 같은 완전 이진 트리

구현

  • 힙을 저장하는 표준적인 자료구조는 배열
  • 구현을 쉽게 하기 위해 배열의 첫 번째 인덱스인 0은 사용되지 않음
  • 특정 위치의 노드 번호는 새로운 노드가 추가되어도 변하지 않음
  • (ex. 루트 노드(1)의 오른쪽 노드 번호는 항상 3)

부모 노드와 자식 노드 관계

왼쪽 자식 index = (부모 index) * 2
오른쪽 자식 index = (부모 index) * 2 + 1
부모 index = (자식 index) / 2

 

힙의 삽입

  1. 힙에 새로운 요소가 들어오면, 일단 새로운 노드를 힙의 마지막 노드에 삽입
  2. 새로운 노드를 부모 노드들과 교환

최대 힙 삽입 구현

void insert_max_heap(int x) {
maxHeap[++heapSize] = x;
// 힙 크기를 하나 증가하고, 마지막 노드에 x를 넣음
for( int i = heapSize; i > 1; i /= 2) {
// 마지막 노드가 자신의 부모 노드보다 크면 swap
if(maxHeap[i/2] < maxHeap[i]) {
swap(i/2, i);
} else {
break;
}
}
}
  • 부모 노드는 자신의 인덱스의 /2 이므로, 비교하고 자신이 더 크면 swap하는 방식

힙의 삭제

  1. 최대 힙에서 최대값은 루트 노드이므로 루트 노드가 삭제됨 (최대 힙에서 삭제 연산은 최대값 요소를 삭제하는 것)
  2. 삭제된 루트 노드에는 힙의 마지막 노드를 가져옴
  3. 힙을 재구성

최대 힙 삭제 구현

int delete_max_heap() {
if(heapSize == 0) // 배열이 비어있으면 리턴
return 0;
int item = maxHeap[1]; // 루트 노드의 값을 저장
maxHeap[1] = maxHeap[heapSize]; // 마지막 노드 값을 루트로 이동
maxHeap[heapSize--] = 0; // 힙 크기를 하나 줄이고 마지막 노드 0 초기화
for(int i = 1; i*2 <= heapSize;) {
// 마지막 노드가 왼쪽 노드와 오른쪽 노드보다 크면 끝
if(maxHeap[i] > maxHeap[i*2] && maxHeap[i] > maxHeap[i*2+1]) {
break;
}
// 왼쪽 노드가 더 큰 경우, swap
else if (maxHeap[i*2] > maxHeap[i*2+1]) {
swap(i, i*2);
i = i*2;
}
// 오른쪽 노드가 더 큰 경우
else {
swap(i, i*2+1);
i = i*2+1;
}
}
return item;
}
저작자표시 비영리 변경금지 (새창열림)

'CS 지식 > [자료구조]' 카테고리의 다른 글

[자료구조] 이진 탐색 트리(Binary Search Tree)  (0) 2023.07.19
[자료구조] 트리(Tree)  (0) 2023.07.19
[자료구조] 스택 & 큐  (0) 2023.07.19
[자료구조] Array vs ArrayList vs LinkedList  (0) 2023.07.19
[자료구조] 연결 리스트(Linked List)  (1) 2023.07.19
  1. 우선순위 큐
  2. 힙(Heap)
  3. 힙 종류
  4. 1) 최대 힙(max heap)
  5. 2) 최소 힙(min heap)
  6. 구현
  7. 부모 노드와 자식 노드 관계
  8. 힙의 삽입
  9. 힙의 삭제
'CS 지식/[자료구조]' 카테고리의 다른 글
  • [자료구조] 이진 탐색 트리(Binary Search Tree)
  • [자료구조] 트리(Tree)
  • [자료구조] 스택 & 큐
  • [자료구조] Array vs ArrayList vs LinkedList
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (827)
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (443)
        • 백준[JAVA] (106)
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    Oracle
    Flutter
    스프링
    JPA
    springboot
    Spring Security
    플러터
    Linux
    Java
    CS
    스프링부트
    리눅스
    baekjoon
    스프링 부트 쇼핑몰 프로젝트 with JPA
    programmers
    postgresql
    데이터베이스
    데이터
    python
    backjoon
    CS지식
    프로그래머스
    리눅스마스터
    백준
    DB
    리눅스마스터 1급
    pcce 기출문제
    spring
    자바
    시큐리티
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[자료구조] 힙(Heap)

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.