Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Data Structure, heap

들어가기 전

  • 스택(stack) : 먼저들어온게 나중에 나간다
  • 큐 (queue) : 먼저들어온게 먼저 나간다
  • 우선순위 큐(priority queue) : 가장 우선순위가 높은게 먼저 나간다
  • 우선순위 큐는 배열, 연결리스트, 힙으로 구현 가능하다.

힙’heap’ 이란?

  • 최댓값, 최솟값을 찾아내는 연산을 빠르게 하기 위해 고안된 완전 이진트리를 기본으로 한 자료구조이다.
  • 우선순위 큐를 위하여 만들어진 자료구조이다.
  • 힙은 일종의 반 정렬 상태(느슨한 정렬 상태)를 유지한다.
    • 큰 값이 상위 레벨에 있고 작은 값이 하위 레벨에 있다는 정도
    • 간단히 말하면 부모 노드의 키 값이 자식 노드의 키 값보다 항상 큰 (작은) 이진 트리를 말한다.
  • 힙 트리에서는 중복된 값을 허용한다. (이진 탐색 트리에서는 중복된 값을 허용하지 않는다.)

힙의 종류

types-of-heap


힙의 구현

  • 힙을 저장하는 표준적인 자료구조는 배열
  • 구현을 쉽게 하기 위해 index 0은 사용 안한다
  • 힙에서의 부모 노드와 자식 노드의 관계
    • 왼쪽 자식 = 부모 * 2
    • 오른쪽 자식 = 부모 * 2 + 1
    • 부모 = 자식 / 2 heap-index-parent-child

힙의 삽입

maxheap-insertion


힙의 삭제

maxheap-delete


Reference

https://gmlwjd9405.github.io/2018/05/10/data-structure-heap.html

Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...