#include <stdio.h> #include <stdlib.h> struct AVLNode { int data; struct AVLNode* left; struct AVLNode* right; int height; }; int height(struct AVLNode* node) { if (node == NULL) { return 0; } return node->height; } int max(int a, int b) { return (a > b) ? a : b; } struct AVLNode* newNode(int data) { struct AVLNode* node = (struct AVLNode*)malloc(sizeof(struct AVLNode)); node->data = data; node->left = NULL; node->right = NULL; node->height = 1; return node; } struct AVLNode* rightRotate(struct AVLNode* y) { struct AVLNode* x = y->left; struct AVLNode* T2 = x->right; x->right = y; y->left = T2; y->height = max(height(y->left), height(y->right)) + 1; x->height = max(height(x->left), height(x->right)) + 1; return x; } struct AVLNode* leftRotate(struct AVLNode* x) { struct AVLNode* y = x->right; struct AVLNode* T2 = y->left; y->left = x; x->right = T2; x->height = max(height(x->left), height(x->right)) + 1; y->height = max(height(y->left), height(y->right)) + 1; return y; } int getBalance(struct AVLNode* node) { if (node == NULL) { return 0; } return height(node->left) - height(node->right); } struct AVLNode* insert(struct AVLNode* node, int data) { if (node == NULL) { return newNode(data); } if (data < node->data) { node->left = insert(node->left, data); } else if (data > node->data) { node->right = insert(node->right, data); } else { return node; } node->height = 1 + max(height(node->left), height(node->right)); int balance = getBalance(node); if (balance > 1 && data < node->left->data) { return rightRotate(node); } if (balance < -1 && data > node->right->data) { return leftRotate(node); } if (balance > 1 && data > node->left->data) { node->left = leftRotate(node->left); return rightRotate(node); } if (balance < -1 && data < node->right->data) { node->right = rightRotate(node->right); return leftRotate(node); } return node; } void inOrder(struct AVLNode* root) { if (root != NULL) { inOrder(root->left); printf("%d ", root->data); inOrder(root->right); } } int main() { struct AVLNode* root = NULL; root = insert(root, 10); root = insert(root, 20); root = insert(root, 30); root = insert(root, 40); root = insert(root, 50); root = insert(root, 25); printf("In-order traversal of the constructed AVL tree:\n"); inOrder(root); return 0; }