It is highly recommended to see previous articles on Van Emde Boas Tree first.
Procedure for Insert :
- If no keys are present in the tree then simply assign minimum and maximum of the tree to the key.
- Otherwise we will go deeper in the tree and do the following:
- If the key we want to insert is less than the current minimum of the tree, then we swap both values because the new key will be the real minimum of the tree and the key which was already at the place of the minimum will be used for the further process. 
 This concept can be thought of as lazy propagation in Van Emde Boas Tree. Because this old minimum value really is a minimum of one of the clusters of recursive Van Emde Boas Structure. So actually we don’t go deeper into the structure until the need arises.
- If we are not at the base case means universe size of the tree is greater than 2 then :
- If the tree’s cluster[High(key)] is empty, then we recursively call insert over the summary and as we are doing lazy propagation, we just assign minimum and maximum value to the key and stop the recursion.
- Otherwise, we call insert over the cluster in which the key is present.
 
 
- If the key we want to insert is less than the current minimum of the tree, then we swap both values because the new key will be the real minimum of the tree and the key which was already at the place of the minimum will be used for the further process. 
- Similarly, We check for maximum and set the key as maximum if it is greater than the current maximum.
Below Image represents empty VEB(4) Tree:
Now we insert 1, then it will just set the minimum and maximum of the tree to 1. You can see the Lazy propagation of 1:
Now if we insert 0, then 1 will propagate to the 1st cluster and zero will be the new minimum:
Procedure for isMember Query :
- At any point of our search, If the key is minimum or maximum of the tree, which means the key is present, then return true.
- If we reach the base case, but above condition is false then the key must not be present in the tree so return true.
- Otherwise recursively call the function over the cluster of the key i.e.(High(key)) and its position in the cluster i.e.(Low(key)).
- Here we are allowing universe_size to be any power of 2, so that if the situation arises in which universe_size is less than the key value then return false.
Minimum & Maximum : Van Emde Boas Tree stores minimum and maximum as its attributes, so we can return its value if it is present and null otherwise.
 
C++
| #include <bits/stdc++.h>usingnamespacestd;classVan_Emde_Boas {public:    intuniverse_size;    intminimum;    intmaximum;    Van_Emde_Boas* summary;    vector<Van_Emde_Boas*> clusters;    // Function to return cluster numbers    // in which key is present    inthigh(intx)    {        intdiv= ceil(sqrt(universe_size));        returnx / div;    }    // Function to return position of x in cluster    intlow(intx)    {        intmod = ceil(sqrt(universe_size));        returnx % mod;    }    // Function to return the index from    // cluster number and position    intgenerate_index(intx, inty)    {        intru = ceil(sqrt(universe_size));        returnx * ru + y;    }    // Constructor    Van_Emde_Boas(intsize)    {        universe_size = size;        minimum = -1;        maximum = -1;        // Base case        if(size <= 2) {            summary = nullptr;            clusters = vector<Van_Emde_Boas*>(0, nullptr);        }        else{            intno_clusters = ceil(sqrt(size));            // Assigning VEB(sqrt(u)) to summary            summary = newVan_Emde_Boas(no_clusters);            // Creating array of VEB Tree pointers of size sqrt(u)            clusters = vector<Van_Emde_Boas*>(no_clusters, nullptr);            // Assigning VEB(sqrt(u)) to all its clusters            for(inti = 0; i < no_clusters; i++) {                clusters[i] = newVan_Emde_Boas(ceil(sqrt(size)));            }        }    }};// Function to return the minimum value// from the tree if it existsintVEB_minimum(Van_Emde_Boas* helper){    return(helper->minimum == -1 ? -1 : helper->minimum);}// Function to return the maximum value// from the tree if it existsintVEB_maximum(Van_Emde_Boas* helper){    return(helper->maximum == -1 ? -1 : helper->maximum);}// Function to insert a key in the treevoidinsert(Van_Emde_Boas* helper, intkey){    // If no key is present in the tree    // then set both minimum and maximum    // to the key (Read the previous article    // for more understanding about it)    if(helper->minimum == -1) {        helper->minimum = key;        helper->maximum = key;    }    else{        if(key < helper->minimum) {            // If the key is less than current minimum            // then swap it with the current minimum            // because this minimum is actually            // minimum of one of the internal cluster            // so as we go deeper into the Van Emde Boas            // we need to take that minimum to its real position            // This concept is similar to "Lazy Propagation"            swap(helper->minimum, key);        }        // Not base case then...        if(helper->universe_size > 2) {            // If no key is present in the cluster then insert key into            // both cluster and summary            if(VEB_minimum(helper->clusters[helper->high(key)]) == -1) {                insert(helper->summary, helper->high(key));                // Sets the minimum and maximum of cluster to the key                // as no other keys are present we will stop at this level                // we are not going deeper into the structure like                // Lazy Propagation                helper->clusters[helper->high(key)]->minimum = helper->low(key);                helper->clusters[helper->high(key)]->maximum = helper->low(key);            }            else{                // If there are other elements in the tree then recursively                // go deeper into the structure to set attributes accordingly                insert(helper->clusters[helper->high(key)], helper->low(key));            }        }        // Sets the key as maximum it is greater than current maximum        if(key > helper->maximum) {            helper->maximum = key;        }    }}// Function that returns true if the// key is present in the treeboolisMember(Van_Emde_Boas* helper, intkey){    // If universe_size is less than the key    // then we can not search the key so returns    // false    if(helper->universe_size < key) {        returnfalse;    }    // If at any point of our traversal    // of the tree if the key is the minimum    // or the maximum of the subtree, then    // the key is present so returns true    if(helper->minimum == key || helper->maximum == key) {        returntrue;    }    else{        // If after attending above condition,        // if the size of the tree is 2 then        // the present key must be        // maximum or minimum of the tree if it        // is not then it returns false because key        // can not be present in the sub tree        if(helper->universe_size == 2) {            returnfalse;        }        else{            // Recursive call over the cluster            // in which the key can be present            // and also pass the new position of the key            // i.e., low(key)            returnisMember(helper->clusters[helper->high(key)],                            helper->low(key));        }    }}// Driver codeintmain(){    Van_Emde_Boas* veb = newVan_Emde_Boas(8);    // Inserting Keys    insert(veb, 2);    insert(veb, 3);    insert(veb, 6);    cout << boolalpha;    // Checking isMember query    cout << isMember(veb, 3) << endl;    cout << isMember(veb, 4) << endl;    // Maximum of VEB    cout << VEB_maximum(veb) << endl;    // Minimum of VEB    cout << VEB_minimum(veb) << endl;} | 
Java
| importjava.util.*;classVan_Emde_Boas {    intuniverse_size;    intminimum;    intmaximum;    Van_Emde_Boas summary;    ArrayList<Van_Emde_Boas> clusters;    // Function to return cluster numbers    // in which key is present    inthigh(intx)    {        intdiv = (int)Math.ceil(Math.sqrt(universe_size));        returnx / div;    }    // Function to return position of x in cluster    intlow(intx)    {        intmod = (int)Math.ceil(Math.sqrt(universe_size));        returnx % mod;    }    // Function to return the index from    // cluster number and position    intgenerate_index(intx, inty)    {        intru = (int)Math.ceil(Math.sqrt(universe_size));        returnx * ru + y;    }    // Constructor    Van_Emde_Boas(intsize)    {        universe_size = size;        minimum = -1;        maximum = -1;        // Base case        if(size <= 2) {            summary = null;            clusters = newArrayList<Van_Emde_Boas>(0);        }        else{            intno_clusters                = (int)Math.ceil(Math.sqrt(size));            // Assigning VEB(sqrt(u)) to summary            summary = newVan_Emde_Boas(no_clusters);            // Creating array of VEB Tree pointers to size            // sqrt(u)            clusters                = newArrayList<Van_Emde_Boas>(no_clusters);            // Assigning VEB(sqrt(u)) to all its clusters            for(inti = 0; i < no_clusters; i++) {                clusters.add(newVan_Emde_Boas(                    (int)Math.ceil(Math.sqrt(size))));            }        }    }}classMain {    // Function to return the minimum value    // from the tree if it exists    staticintVEB_minimum(Van_Emde_Boas helper)    {        return(helper.minimum == -1? -1: helper.minimum);    }    // Function to return the maximum value    // from the tree if it exists    staticintVEB_maximum(Van_Emde_Boas helper)    {        return(helper.maximum == -1? -1: helper.maximum);    }    // Function to insert a key in the tree    staticvoidinsert(Van_Emde_Boas helper, intkey)    {        // If no key is present in the tree        // then set both minimum and maximum        // to the key (Read the previous article        // for more understanding about it)        if(helper.minimum == -1) {            helper.minimum = key;            helper.maximum = key;        }        else{            if(key < helper.minimum) {                // If the key is less than current minimum                // then swap it with the current minimum                // because this minimum is actually                // minimum of one of the internal cluster                // so as we go deeper into the Van Emde Boas                // we need to take that minimum to its real                // position This concept is similar to "Lazy                // Propagation"                inttemp = helper.minimum;                helper.minimum = key;                key = temp;            }            // not base case then..            if(helper.universe_size > 2) {                // If no key is present in the cluster then                // insert key into both cluster and summary                if(VEB_minimum(helper.clusters.get(                        helper.high(key)))                    == -1) {                    insert(helper.summary,                           helper.high(key));                    // Sets the minimum and maximum of                    // cluster to the key                    // as no other keys are present we will                    // stop at this level we are not going                    // deeper into the structure like Lazy                    // Propagation                    helper.clusters.get(helper.high(key))                        .minimum                        = helper.low(key);                    helper.clusters.get(helper.high(key))                        .maximum                        = helper.low(key);                }                else{                    // If there are other elements in the                    // tree then recursively                    // go deeper into the structure to set                    // attributes accordingly                    insert(helper.clusters.get(                               helper.high(key)),                           helper.low(key));                }            }            // Sets the key as maximum it is greater than            // current maximum            if(key > helper.maximum) {                helper.maximum = key;            }        }    }    // Function that returns true if the    // key is present in the tree    staticbooleanisMember(Van_Emde_Boas helper, intkey)    {        // If universe_size is less than the key        // then we can not search the key so returns        // false        if(helper.universe_size < key) {            returnfalse;        }        // If at any point of our traversal        // of the tree if the key is the minimum        // or the maximum of the subtree, then        // the key is present so returns true        if(helper.minimum == key            || helper.maximum == key) {            returntrue;        }        else{            // If after attending above condition,            // if the size of the tree is 2 then            // the present key must be            // maximum or minimum of the tree if it            // is not then it returns false because key            // can not be present in the sub tree            if(helper.universe_size == 2) {                returnfalse;            }            else{                // Recursive call over the cluster                // in which the key can be present                // and also pass the new position of the key                // i.e., low(key)                returnisMember(                    helper.clusters.get(helper.high(key)),                    helper.low(key));            }        }    }    // Main Function    publicstaticvoidmain(String[] args)    {        Van_Emde_Boas veb = newVan_Emde_Boas(8);        // Inserting Keys        insert(veb, 2);        insert(veb, 3);        insert(veb, 6);        // Checking isMember Query        System.out.println(            Boolean.toString(isMember(veb, 3)));        System.out.println(            Boolean.toString(isMember(veb, 4)));        // Maximum of VEB        System.out.println(VEB_maximum(veb));        // Minimum of VEB        System.out.println(VEB_minimum(veb));    }} | 
Python3
| importmathclassVan_Emde_Boas:    # Constructor    def__init__(self, size):        self.universe_size =size        self.minimum =-1        self.maximum =-1        # Basecase        ifsize <=2:            self.summary =None            self.clusters =[None] *0        else:            no_clusters =math.ceil(math.sqrt(size))                        # Assigning VEB(sqrt(u)) to summary            self.summary =Van_Emde_Boas(no_clusters)                        # Creating array of VEB Tree pointers of size sqrt(u)            # Assigning VEB(sqrt(u)) to all its clusters            self.clusters =[Van_Emde_Boas(                math.ceil(math.sqrt(size))) fori inrange(no_clusters)]    # Function to return cluster numbers    # in which key is present    defhigh(self, x):        div =math.ceil(math.sqrt(self.universe_size))        returnx //div    # Function to return position of x in cluster    deflow(self, x):        mod =math.ceil(math.sqrt(self.universe_size))        returnx %mod    # Function to return the index from    #  cluster number and position    defgenerate_index(self, x, y):        ru =math.ceil(math.sqrt(self.universe_size))        returnx *ru +y# Function to return the minimum value# from the tree if it existsdefVEB_minimum(helper):    return-1ifhelper.minimum ==-1elsehelper.minimum# Function to return the maximum value# from the tree if it existsdefVEB_maximum(helper):    return-1ifhelper.maximum ==-1elsehelper.maximum# Function to insert a key in the treedefinsert(helper, key):    # If no key is present in the tree    # then set both minimum and maximum    # to the key (Read the previous article    # for more understanding about it)    ifhelper.minimum ==-1:        helper.minimum =key        helper.maximum =key    else:        ifkey < helper.minimum:            # If the key is less than current minimum            # then swap it with the current minimum            # because this minimum is actually            # minimum of one of the internal cluster            # so as we go deeper into the Van Emde Boas            # we need to take that minimum to its real position            # This concept is similar to "Lazy Propagation"            helper.minimum, key =key, helper.minimum        # Not base case then        ifhelper.universe_size > 2:            # If no key is present in the cluster then insert key into            # both cluster and summary            ifVEB_minimum(helper.clusters[helper.high(key)]) ==-1:                insert(helper.summary, helper.high(key))                # Sets the minimum and maximum of cluster to the key                # as no other keys are present we will stop at this level                # we are not going deeper into the structure like                # Lazy Propagation                helper.clusters[helper.high(key)].minimum =helper.low(key)                helper.clusters[helper.high(key)].maximum =helper.low(key)            else:                # If there are other elements in the tree then recursively                # go deeper into the structure to set attributes accordingly                insert(helper.clusters[helper.high(key)], helper.low(key))        # Sets the key as maximum it is greater than current maximum        ifkey > helper.maximum:            helper.maximum =key# Function that returns true if the# key is present in the treedefisMember(helper, key):    # If universe_size is less than the key    # then we can not search the key so returns    # false    ifhelper.universe_size < key:        returnFalse    # If at any point of our traversal    # of the tree if the key is the minimum    # or the maximum of the subtree, then    # the key is present so returns true    ifhelper.minimum ==key orhelper.maximum ==key:        returnTrue    # If after attending above condition,    # if the size of the tree is 2 then    # the present key must be    # maximum or minimum of the tree if it    # is not then it returns false because key    # can not be present in the sub tree    ifhelper.universe_size ==2:        returnFalse    # Recursive call over the cluster    # in which the key can be present    # and also pass the new position of the key    # i.e., low(key)    returnisMember(helper.clusters[helper.high(key)], helper.low(key))veb =Van_Emde_Boas(8)# Inserting keysinsert(veb, 2)insert(veb, 3)insert(veb, 6)# Checking isMember queryprint(isMember(veb, 3), end='\n')print(isMember(veb, 4), end='\n')# Maximum of VEBprint(VEB_maximum(veb), end='\n')# Minimum of VEBprint(VEB_minimum(veb), end='\n') | 
Javascript
| class Van_Emde_Boas {  constructor(size) {    this.universe_size = size;    this.minimum = -1;    this.maximum = -1;    if(size <= 2) {      this.summary = null;      this.clusters = Array(0).fill(null);    } else{      const no_clusters = Math.ceil(Math.sqrt(size));      this.summary = newVan_Emde_Boas(no_clusters);      this.clusters = Array(no_clusters).fill(null).map(() => newVan_Emde_Boas(Math.ceil(Math.sqrt(size))));    }  }    // Function to return cluster numbers    // in which key is present  high(x) {    const div = Math.ceil(Math.sqrt(this.universe_size));    returnMath.floor(x / div);  }    // Function to return position of x in cluster  low(x) {    const mod = Math.ceil(Math.sqrt(this.universe_size));    returnx % mod;  }    // Function to return the index from    // cluster number and position  generate_index(x, y) {    const ru = Math.ceil(Math.sqrt(this.universe_size));    returnx * ru + y;  }}// Function to return the minimum value// from the tree if it existsfunctionVEB_minimum(helper) {  returnhelper.minimum === -1 ? -1 : helper.minimum;}// Function to return the maximum value// from the tree if it existsfunctionVEB_maximum(helper) {  returnhelper.maximum === -1 ? -1 : helper.maximum;}// Function to insert a key in the treefunctioninsert(helper, key) {            // If no key is present in the tree    // then set both minimum and maximum    // to the key (Read the previous article    // for more understanding about it)  if(helper.minimum === -1) {    helper.minimum = key;    helper.maximum = key;  } else{                // If the key is less than current minimum            // then swap it with the current minimum            // because this minimum is actually            // minimum of one of the internal cluster    if(key < helper.minimum) {      [helper.minimum, key] = [key, helper.minimum];    }    if(helper.universe_size > 2) {                // If no key is present in the cluster then insert key into            // both cluster and summary      if(VEB_minimum(helper.clusters[helper.high(key)]) === -1) {        insert(helper.summary, helper.high(key));            // Sets the minimum and maximum of cluster to the key            // as no other keys are present we will stop at this level        helper.clusters[helper.high(key)].minimum = helper.low(key);        helper.clusters[helper.high(key)].maximum = helper.low(key);      } else{              // If there are other elements in the tree then recursively                // go deeper into the structure to set attributes accordingly        insert(helper.clusters[helper.high(key)], helper.low(key));      }    }           // Sets the key as maximum it is greater than current maximum    if(key > helper.maximum) {      helper.maximum = key;} }}// Function that returns true if the// key is present in the treefunctionisMember(helper, key) {    // If universe_size is less than the key// then we can not search the key so returns// falseif(helper.universe_size < key) {    returnfalse;}// If at any point of our traversal// of the tree if the key is the minimum// or the maximum of the subtree, then// the key is present so returns trueif(helper.minimum === key || helper.maximum === key) {    returntrue;} else{    // If after attending above condition,    // if the size of the tree is 2 then    // the present key must be    // maximum or minimum of the tree if it    // is not then it returns false because key    // can not be present in the sub tree    if(helper.universe_size === 2) {        returnfalse;    } else{        // Recursive call over the cluster        // in which the key can be present        // and also pass the new position of the key        // i.e., low(key)        returnisMember(helper.clusters[helper.high(key)],                        helper.low(key));    }}}// Usage:const veb = newVan_Emde_Boas(16);// Insertinginsert(veb, 2);insert(veb, 3);insert(veb, 6);// Checking isMember queryconsole.log(isMember(veb, 3));console.log(isMember(veb, 4));// Maximum of VEBconsole.log( VEB_maximum(veb));// Minimum if VEBconsole.log(VEB_minimum(veb));  | 
C#
| usingSystem;usingSystem.Collections.Generic;publicclassVan_Emde_Boas {    publicintuniverse_size;    publicintminimum;    publicintmaximum;    publicVan_Emde_Boas summary;    publicList<Van_Emde_Boas> clusters;    publicVan_Emde_Boas(intsize)    {        universe_size = size;        minimum = -1;        maximum = -1;        // Base case        if(size <= 2) {            summary = null;            clusters = newList<Van_Emde_Boas>(0);        }        else{            intno_clusters                = (int)Math.Ceiling(Math.Sqrt(size));            summary = newVan_Emde_Boas(no_clusters);            clusters                = newList<Van_Emde_Boas>(no_clusters);            for(inti = 0; i < no_clusters; i++) {                clusters.Add(newVan_Emde_Boas(                    (int)Math.Ceiling(Math.Sqrt(size))));            }        }    }    // Function to return cluster numbers    // in which key is present    publicinthigh(intx)    {        intdiv = (int)Math.Ceiling(Math.Sqrt(universe_size));        returnx / div;    }    // Function to return position of x in cluster    publicintlow(intx)    {        intmod = (int)Math.Ceiling(Math.Sqrt(universe_size));        returnx % mod;    }    // Function to return position of x in cluster    publicintgenerate_index(intx, inty)    {        intru = (int)Math.Ceiling(Math.Sqrt(universe_size));        returnx * ru + y;    }}publicclassMain_Program {    // Function to return the minimum value    // from the tree if it exists    publicstaticintVEB_minimum(Van_Emde_Boas helper)    {        return(helper.minimum == -1 ? -1 : helper.minimum);    }    // Function to return the maximum value    // from the tree if it exists    publicstaticintVEB_maximum(Van_Emde_Boas helper)    {        return(helper.maximum == -1 ? -1 : helper.maximum);    }    // Function to insert a key in the tree    staticvoidinsert(Van_Emde_Boas helper, intkey)    {            // If no key is present in the tree        // then set both minimum and maximum        // to the key (Read the previous article        // for more understanding about it)        if(helper.minimum == -1) {            helper.minimum = key;            helper.maximum = key;        }        else{    // If the key is less than the current minimum            // then swap it with the current minimum            // because this minimum is actually            // minimum of one of the internal cluster            if(key < helper.minimum) {                inttemp = helper.minimum;                helper.minimum = key;                key = temp;            }            // Not base case then...            if(helper.universe_size > 2) {                // If no key is present in the cluster then                // insert key into both cluster and summary                if(VEB_minimum(helper.clusters[helper.high(key)])                    == -1) {                    insert(helper.summary,                        helper.high(key));                    // Sets the minimum and maximum of                    // cluster to the key as no other keys                    // are present we will stop at this                    // level                    helper.clusters[helper.high(key)]                        .minimum                        = helper.low(key);                    helper.clusters[helper.high(key)]                        .maximum                        = helper.low(key);                }                else{                    // If there are other elements in the                    // tree then recursively go deeper into                    // the structure to set attributes                    // accordingly                    insert(helper.clusters[                            helper.high(key)],                        helper.low(key));                }            }// Sets the key as maximum it is greater than            // current maximum            if(key > helper.maximum) {                helper.maximum = key;            }        }    }        // Function that returns true if the    // key is present in the treepublicstaticboolisMember(Van_Emde_Boas helper, intkey){    if(helper.universe_size < key)    {        returnfalse;    }    if(helper.minimum == key || helper.maximum == key)    {        returntrue;    }    else    {            // If after attending above condition,if the            // size of the tree is 2 then the present key            // must be maximum or minimum of the tree        if(helper.universe_size == 2)        {            returnfalse;        }        else        {            returnisMember(helper.clusters[helper.high(key)], helper.low(key));        }    }}        // Driver code    publicstaticvoidMain() {        Van_Emde_Boas veb = newVan_Emde_Boas(8);                // Inserting        insert(veb, 2);        insert(veb, 3);        insert(veb, 6);               // Checking isMember query        Console.WriteLine(isMember(veb,3));        Console.WriteLine(isMember(veb,4));                // Maximum ov VEB        Console.WriteLine(VEB_maximum(veb));                // Minimum of VEB        Console.WriteLine(VEB_minimum(veb));    }} | 
true false 6 2
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 neveropen!


 
                                    








