Skip to content

Latest commit

 

History

History
47 lines (33 loc) · 2.49 KB

File metadata and controls

47 lines (33 loc) · 2.49 KB

Heaps


What are Heaps?

A Heap is a special case of a binary tree where the parent nodes are compared to their children with their values and are arranged accordingly. Let us see how we can represent heaps. Heaps can be represented using trees as well as arrays. Figures 7 and 8 show how we can represent a binary heap using a binary tree and an array.

Heap Image 1

Heap Image 2

Types of Heaps

You should use heap when you require to allocate a large block of memory. For example, you want to create a large size array or big structure to keep that variable around a long time then you should allocate it on the heap.

  • Min Heap — the key of the parent is less than or equal to those of its children. This is called the min-heap property. The root will contain the minimum value of the heap.
  • Max Heap — the key of the parent is greater than or equal to those of its children. This is called the max-heap property. The root will contain the maximum value of the heap.

Advantages of Heaps

  • Heap helps you to find the greatest and minimum number
  • Garbage collection runs on the heap memory to free the memory used by the object.
  • Heap method also used in the Priority Queue.
  • It allows you to access variables globally.
  • Heap doesn't have any limit on memory size.

Disadvantages of Heaps

  • It can provide the maximum memory an OS can provide
  • It takes more time to compute.
  • Memory management is more complicated in heap memory as it is used globally.
  • It takes too much time in execution compared to the stack.

Resources