2023-03-05 03:05:41 -06:00
|
|
|
#ifndef TREES_HPP
|
|
|
|
#define TREES_HPP
|
|
|
|
|
2023-03-06 21:54:40 -06:00
|
|
|
#include <fstream>
|
2023-03-05 23:13:34 -06:00
|
|
|
#include <memory>
|
2023-03-05 03:05:41 -06:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
// Namespace for different implementations of trees
|
|
|
|
namespace tree_implementation
|
|
|
|
{
|
2023-03-05 23:13:34 -06:00
|
|
|
// General nodes for Tree
|
|
|
|
struct TreeNode
|
|
|
|
{
|
|
|
|
std::string key;
|
|
|
|
std::string color;
|
2023-03-06 03:13:14 -06:00
|
|
|
std::shared_ptr<TreeNode> leftChild;
|
|
|
|
std::shared_ptr<TreeNode> rightChild;
|
|
|
|
std::shared_ptr<TreeNode> parent;
|
2023-03-05 23:13:34 -06:00
|
|
|
TreeNode(std::string word);
|
|
|
|
};
|
|
|
|
|
|
|
|
// General list for Tree
|
|
|
|
class TreeList
|
2023-03-05 03:05:41 -06:00
|
|
|
{
|
|
|
|
public:
|
2023-03-06 03:13:14 -06:00
|
|
|
std::shared_ptr<TreeNode> head;
|
2023-03-05 23:13:34 -06:00
|
|
|
TreeList(void);
|
|
|
|
void InsertAtStart(std::string word);
|
|
|
|
void InsertAtEnd(std::string word);
|
|
|
|
void InsertAtPosition(std::string word);
|
|
|
|
void Remove(std::string word);
|
|
|
|
void Print(void);
|
2023-03-05 03:05:41 -06:00
|
|
|
protected:
|
2023-03-05 23:13:34 -06:00
|
|
|
;
|
2023-03-05 03:05:41 -06:00
|
|
|
private:
|
|
|
|
;
|
|
|
|
};
|
|
|
|
|
2023-03-05 23:13:34 -06:00
|
|
|
// Base Tree class
|
|
|
|
class TreeInterface
|
2023-03-05 03:05:41 -06:00
|
|
|
{
|
|
|
|
public:
|
2023-03-05 23:13:34 -06:00
|
|
|
TreeList tree;
|
|
|
|
TreeInterface(void);
|
2023-03-06 21:54:40 -06:00
|
|
|
void Search(std::string key);
|
|
|
|
std::shared_ptr<TreeNode> GetNodeWithWord(std::string wordToFind);
|
2023-03-06 03:13:14 -06:00
|
|
|
void InOrderTreeTraversal(std::shared_ptr<TreeNode> viewedNode);
|
2023-03-06 22:24:59 -06:00
|
|
|
void InOrderTreeTraversal(std::shared_ptr<TreeNode> viewedNode, std::ofstream* file);
|
2023-03-05 03:05:41 -06:00
|
|
|
void PrintParentKey(std::string key);
|
|
|
|
void PrintLeftChild(std::string key);
|
|
|
|
void PrintRightChild(std::string key);
|
2023-03-05 23:13:34 -06:00
|
|
|
protected:
|
2023-03-06 21:54:40 -06:00
|
|
|
bool IsNodeSearchSuccessful(std::shared_ptr<TreeNode> foundNode, std::string key);
|
2023-03-06 03:13:14 -06:00
|
|
|
virtual void Insert(std::shared_ptr<TreeNode> z);
|
|
|
|
virtual void InsertWordList(std::vector<std::string>* newWordList) = 0;
|
2023-03-05 23:13:34 -06:00
|
|
|
virtual void PrintPathToRoot(std::string key) = 0;
|
|
|
|
private:
|
2023-03-06 21:54:40 -06:00
|
|
|
std::shared_ptr<TreeNode> GetNodeWithWord(std::shared_ptr<TreeNode> viewedNode, std::string wordToFind);
|
2023-03-05 23:13:34 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
// Binary Search Tree operations
|
|
|
|
class BinarySearchTree : public TreeInterface
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
void Insert(std::string keyToInsert);
|
2023-03-06 03:13:14 -06:00
|
|
|
void InsertWordList(std::vector<std::string>* newWordList);
|
2023-03-05 03:05:41 -06:00
|
|
|
void PrintPathToRoot(std::string key);
|
|
|
|
protected:
|
|
|
|
;
|
|
|
|
private:
|
|
|
|
;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Red-Black Tree operations
|
2023-03-05 23:13:34 -06:00
|
|
|
class RedBlackTree : public TreeInterface
|
2023-03-05 03:05:41 -06:00
|
|
|
{
|
|
|
|
public:
|
2023-03-05 23:13:34 -06:00
|
|
|
void Insert(std::string keyToInsert);
|
2023-03-06 03:13:14 -06:00
|
|
|
void InsertWordList(std::vector<std::string>* newWordList);
|
2023-03-05 03:05:41 -06:00
|
|
|
void PrintPathToRoot(std::string key);
|
|
|
|
void PrintColor(std::string key);
|
|
|
|
void PrintParentColor(std::string key);
|
|
|
|
void PrintUncleColor(std::string key);
|
|
|
|
protected:
|
|
|
|
;
|
|
|
|
private:
|
2023-03-06 03:13:14 -06:00
|
|
|
void InsertFixup(std::shared_ptr<TreeNode> z);
|
|
|
|
std::shared_ptr<TreeNode> GetUncleNode(std::shared_ptr<TreeNode> startNode);
|
|
|
|
void LeftRotate(std::shared_ptr<TreeNode> x);
|
|
|
|
void RightRotate(std::shared_ptr<TreeNode> x);
|
2023-03-05 03:05:41 -06:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|