C++ tree implementation using vectors
Build with optimizations
#include<iostream>
#include "cpptree.h"
int main() {
    vector_tree<std::string> mytree; // Set stored data type
    mytree.addNode(0); // Add to node 0
    mytree.addNode(0);
    int nodenum = mytree.addNode(2); // Return value is the new nodes number
    mytree.addNode(nodenum); // Add a new node to the node added to 2
    mytree.setName(nodenum, "Some string here"); // Set the value of nodenum (the node added to 2) to a string (or other data type)
    int new_nodenum = mytree.addNode(nodenum);
    mytree.addNode(new_nodenum);
    mytree.removeNode(new_nodenum); // removeNode removes a Node (recursively of course!)
    // When a node is removed, all nodes with a higher number move 1 number down, to fill the number gap - there's never an unused number!
    std::cout << mytree.getName(3); // Get value at node 3 (in this case a string)
    std::vector<int> children = mytree.getChildren(1); // Store all (immediate) children of node 1
    std::vector<int> allchildren = mytree.getAllChildren(1); // Store all children of node 1 (recursively)
    int parent_of_3 = mytree.getParent(3); // Get parent of node 3
    mytree.printTree();
}