TheAlgorithms-C-Plus-Plus/Data Structure/AVLtree.cpp

177 lines
3.1 KiB
C++
Raw Normal View History

2018-10-11 13:15:50 +08:00
#include <iostream>
#include <queue>
using namespace std;
2019-08-21 10:10:08 +08:00
typedef struct node
{
2018-10-11 13:15:50 +08:00
int data;
int height;
2019-08-21 10:10:08 +08:00
struct node *left;
struct node *right;
} node;
2018-10-11 13:15:50 +08:00
2019-08-21 10:10:08 +08:00
int max(int a, int b)
{
2018-10-11 13:15:50 +08:00
return a > b ? a : b;
}
2018-10-11 15:23:27 +08:00
// Returns a new Node
2019-08-21 10:10:08 +08:00
node *createNode(int data)
{
2018-10-11 13:15:50 +08:00
node *nn = new node();
nn->data = data;
nn->height = 0;
nn->left = NULL;
nn->right = NULL;
return nn;
}
// Returns height of tree
2018-10-11 15:23:27 +08:00
2019-08-21 10:10:08 +08:00
int height(node *root)
{
if (root == NULL)
2018-10-11 13:15:50 +08:00
return 0;
return 1 + max(height(root->left), height(root->right));
}
// Returns difference between height of left and right subtree
2018-10-11 15:23:27 +08:00
2019-08-21 10:10:08 +08:00
int getBalance(node *root)
{
2018-10-11 13:15:50 +08:00
return height(root->left) - height(root->right);
}
2018-10-11 15:23:27 +08:00
// Returns Node after Right Rotation
2019-08-21 10:10:08 +08:00
node *rightRotate(node *root)
{
2018-10-11 13:15:50 +08:00
node *t = root->left;
node *u = t->right;
t->right = root;
root->left = u;
return t;
}
2018-10-11 15:23:27 +08:00
// Returns Node after Left Rotation
2019-08-21 10:10:08 +08:00
node *leftRotate(node *root)
{
2018-10-11 13:15:50 +08:00
node *t = root->right;
node *u = t->left;
t->left = root;
root->right = u;
return t;
}
2018-10-11 15:23:27 +08:00
// Returns node with minimum value in the tree
2019-08-21 10:10:08 +08:00
node *minValue(node *root)
{
if (root->left == NULL)
2018-10-11 15:23:27 +08:00
return root;
return minValue(root->left);
}
// Balanced Insertion
2019-08-21 10:10:08 +08:00
node *insert(node *root, int item)
{
2018-10-11 13:15:50 +08:00
node *nn = createNode(item);
2019-08-21 10:10:08 +08:00
if (root == NULL)
2018-10-11 13:15:50 +08:00
return nn;
2019-08-21 10:10:08 +08:00
if (item < root->data)
2018-10-11 13:15:50 +08:00
root->left = insert(root->left, item);
else
root->right = insert(root->right, item);
int b = getBalance(root);
2019-08-21 10:10:08 +08:00
if (b > 1)
{
if (getBalance(root->left) < 0)
root->left = leftRotate(root->left); // Left-Right Case
return rightRotate(root); // Left-Left Case
2018-10-11 13:15:50 +08:00
}
2019-08-21 10:10:08 +08:00
else if (b < -1)
{
if (getBalance(root->right) > 0)
root->right = rightRotate(root->right); // Right-Left Case
return leftRotate(root); // Right-Right Case
2018-10-11 13:15:50 +08:00
}
return root;
}
2018-10-11 15:23:27 +08:00
// Balanced Deletion
2019-08-21 10:10:08 +08:00
node *deleteNode(node *root, int key)
{
if (root == NULL)
2018-10-11 15:23:27 +08:00
return root;
2019-08-21 10:10:08 +08:00
if (key < root->data)
2018-10-11 15:23:27 +08:00
root->left = deleteNode(root->left, key);
2019-08-21 10:10:08 +08:00
else if (key > root->data)
2018-10-11 15:23:27 +08:00
root->right = deleteNode(root->right, key);
2019-08-21 10:10:08 +08:00
else
{
2018-10-11 15:23:27 +08:00
// Node to be deleted is leaf node or have only one Child
2019-08-21 10:10:08 +08:00
if (!root->right)
{
node *temp = root->left;
delete (root);
2018-10-11 15:23:27 +08:00
root = NULL;
return temp;
}
2019-08-21 10:10:08 +08:00
else if (!root->left)
{
node *temp = root->right;
delete (root);
2018-10-11 15:23:27 +08:00
root = NULL;
return temp;
}
// Node to be deleted have both left and right subtrees
node *temp = minValue(root->right);
root->data = temp->data;
root->right = deleteNode(root->right, temp->data);
}
// Balancing Tree after deletion
return root;
}
// LevelOrder (Breadth First Search)
2019-08-21 10:10:08 +08:00
void levelOrder(node *root)
{
queue<node *> q;
2018-10-11 13:15:50 +08:00
q.push(root);
2019-08-21 10:10:08 +08:00
while (!q.empty())
{
2018-10-11 13:15:50 +08:00
root = q.front();
2019-08-21 10:10:08 +08:00
cout << root->data << " ";
2018-10-11 13:15:50 +08:00
q.pop();
2019-08-21 10:10:08 +08:00
if (root->left)
2018-10-11 13:15:50 +08:00
q.push(root->left);
2019-08-21 10:10:08 +08:00
if (root->right)
2018-10-11 13:15:50 +08:00
q.push(root->right);
}
}
2019-08-21 10:10:08 +08:00
int main()
{
2018-10-11 13:15:50 +08:00
// Testing AVL Tree
2018-10-11 15:23:27 +08:00
node *root = NULL;
2018-10-11 13:15:50 +08:00
int i;
2019-08-21 10:10:08 +08:00
for (i = 1; i <= 7; i++)
2018-10-11 13:15:50 +08:00
root = insert(root, i);
2019-08-21 10:10:08 +08:00
cout << "LevelOrder: ";
2018-10-11 13:15:50 +08:00
levelOrder(root);
2018-10-11 15:23:27 +08:00
root = deleteNode(root, 1); // Deleting key with value 1
2019-08-21 10:10:08 +08:00
cout << "\nLevelOrder: ";
2018-10-11 15:23:27 +08:00
levelOrder(root);
2019-08-21 10:10:08 +08:00
root = deleteNode(root, 4); // Deletin key with value 4
cout << "\nLevelOrder: ";
2018-10-11 15:23:27 +08:00
levelOrder(root);
2018-10-11 13:15:50 +08:00
return 0;
}