DAA-바이너리 힙

여러 유형의 힙이 있지만이 장에서는 이진 힙에 대해 설명합니다. ㅏbinary heap완전한 이진 트리와 유사한 데이터 구조입니다. 힙 데이터 구조는 아래에 설명 된 순서 지정 속성을 따릅니다. 일반적으로 힙은 배열로 표시됩니다. 이 장에서는 힙을 다음과 같이 표현합니다.H.

힙의 요소가 배열에 저장되므로 시작 인덱스를 다음과 같이 고려합니다. 1, 부모 노드의 위치 ith 요소는 다음에서 찾을 수 있습니다. ⌊ i/2 ⌋. 왼쪽 자식과 오른쪽 자식ith 노드가 위치에 있습니다. 2i2i + 1.

바이너리 힙은 다음 중 하나로 더 분류 될 수 있습니다. max-heap 또는 min-heap 주문 속성을 기반으로합니다.

최대 힙

이 힙에서 노드의 키 값은 가장 높은 하위의 키 값보다 크거나 같습니다.

그 후, H[Parent(i)] ≥ H[i]

최소 힙

평균 힙에서 노드의 키 값은 가장 낮은 자식의 키 값보다 작거나 같습니다.

그 후, H[Parent(i)] ≤ H[i]

이 컨텍스트에서 Max-Heap과 관련된 기본 작업이 아래에 나와 있습니다. 힙에서 요소를 삽입하고 삭제하려면 요소를 다시 정렬해야합니다. 그 후,Heapify 함수를 호출해야합니다.

배열 표현

완전한 이진 트리는 레벨 순서 순회를 사용하여 요소를 저장하는 배열로 나타낼 수 있습니다.

배열로 표현 될 힙 (아래 그림 참조)을 고려해 보겠습니다. H.

시작 색인을 다음과 같이 고려하십시오. 0, 레벨 순서 순회를 사용하면 요소가 다음과 같이 배열에 유지됩니다.

Index 0 1 2 4 5 6 7 8 ...
elements 70 30 50 12 20 35 25 4 8 ...

이 컨텍스트에서 힙에 대한 작업은 Max-Heap과 관련하여 표현됩니다.

index에서 요소 부모의 인덱스를 찾으려면 i, 다음 알고리즘 Parent (numbers[], i) 사용.

Algorithm: Parent (numbers[], i) 
if i == 1 
   return NULL 
else 
   [i / 2]

인덱스에있는 요소의 왼쪽 자식 인덱스 i 다음 알고리즘을 사용하여 찾을 수 있습니다. Left-Child (numbers[], i).

Algorithm: Left-Child (numbers[], i) 
If 2 * i ≤ heapsize 
   return [2 * i] 
else 
   return NULL

인덱스에있는 요소의 오른쪽 자식 인덱스 i 다음 알고리즘을 사용하여 찾을 수 있습니다. Right-Child(numbers[], i).

Algorithm: Right-Child (numbers[], i) 
if 2 * i < heapsize 
   return [2 * i + 1] 
else 
   return NULL