Storing binary trees

Binary trees can be stored in an array as follows:

Indexing of the array starts at 1 1 instead of 0 0 . For an array P P , the root is stored at P [ 1 ] P[1] . For a node stored at P [ i ] P[i] , the left child, if any, is stored in P [ 2 i ] P[2i] and the right child, if any, in P [ 2 i + 1 ] P[2i+1] .

What should be the minimum size of array P P to be able to store any binary tree of n n vertices?

log 2 2 n \log _{ 2 }{ 2n } 2 n 1 2^{n}-1 2 n + 1 2n+1 n n

This section requires Javascript.
You are seeing this because something didn't load right. We suggest you, (a) try refreshing the page, (b) enabling javascript if it is disabled on your browser and, finally, (c) loading the non-javascript version of this page . We're sorry about the hassle.

1 solution

Andrea Temin
Mar 16, 2016

I think that the answer should be 2^h - 1 where h is the height of the tree, in this way you have almost a perfect optimization of the array's length for differents trees with the same number of nodes but with a different permutations.

0 pending reports

×

Problem Loading...

Note Loading...

Set Loading...