베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • jpa
    • Spring
    • 스레드
    • 알고리즘
    • java
    • 토비스프링
    • 자바8
    • 자바
    • C++
    • 백준
    • leetcode
    • 스프링
    • 운영체제
    • 코드업
    • dfs
    • 이펙티브자바
    • 함수형인터페이스
    • 스프링시큐리티
    • BFS
    • 데이터베이스

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    자료구조

    [자료구조] 힙(Heap) 자료구조

    2023. 6. 17. 01:26

    힙 자료구조

       최솟값 또는 최댓값을 루트노드로 가지는 완전이진트리 형태의 자료구조

    완전이진트리

        마지막 노드를 제외한 모든 노드들이 2개의 자식을 갖으며, 마지막 노드의 자식은 왼쪽부터 채워지는 트리

    힙 종류

    1. 최소 힙(Min Heap) : 모든 부모 노드의 값이 자식 노드의 값보다 작거나 같은 완전이진트리
    2. 최대 힙(Max Heap) : 모든 부모 노드의 값이 자식 노드의 값보다 크거나 같은 완전이진트리

    삽입

       44, 33, 77, 11, 55, 88 을 삽입하는 과정을 살펴보자. 

    // 1단계
       44
        
    // 2단계
       44
       /
      33
      
    // 3단계
        44                77
        /\                /\
      33  77	    33  44
      
    // 4단계 ~ 5단계
        77              77
      33  44         55    44
    11 55          11  33
    
    // 6단계
         77                88
      55     44        55     77
    11  33  88       11  33  44

    삭제

       삭제를 할 때는 항상 루트 노드가 삭제되고 이 자리는 맨 마지막 노드와 교체된다.

    // 1단계
          88
          /\
        55  77
        /\  /
      11 33 44
    
    // 2단계
          44
          /\
        55  77
        /\
      11 33   
      
    // 3단계
           77
           /\
         55 44
         /\
       11 33

    시간 복잡도

    • 삽입 : O(log N)
    • 삭제 : O(log N)

    관련 알고리즘 문제

    https://leetcode.com/problems/find-median-from-data-stream/

    저작자표시 비영리 변경금지 (새창열림)
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바