Unbalanced Binary Search Tree with insertion, search, deletion, and DFS printing. Can flatten tree to array, then create balanced tree from array.