#include <stdio.h>
#include <stdlib.h>
enum nodeColor {
RED,
BLACK
};
struct rbNode {
int data, color;
struct rbNode *link[3];
};
struct rbNode *root = NULL;
struct rbNode * createNode(int data) {
struct rbNode *newnode;
newnode
= (struct rbNode
*)malloc(sizeof(struct rbNode
)); newnode->data = data;
newnode->color = RED;
newnode->link[0] = newnode->link[1]=newnode->link[2] = NULL;
return newnode;
}
void insertion (int data) {
struct rbNode *stack[98],*zptr, *ptr, *newnode, *xPtr, *yPtr,*a;
int dir[98], ht = 0, index;
ptr = root;
if (!root) {
root = createNode(data);
return;
}
stack[ht] = root;
dir[ht++] = 0;
/* find the place to insert the new node */
while (ptr != NULL) {
if (ptr->data == data) {
printf("Duplicates Not Allowed!!\n"); return;
}
index = (data - ptr->data) > 0 ? 1 : 0;
a=ptr->data;
stack[ht] = ptr;
ptr = ptr->link[index];
ptr->link[2]=a;
dir[ht++] = index;
}
/* insert the new node */
stack[ht - 1]->link[index] = newnode = createNode(data);
while ((ht >= 3) && (stack[ht - 1]->color == RED)) {
if (dir[ht - 2] == 0) {
yPtr = stack[ht - 2]->link[1];
if (yPtr != NULL && yPtr->color == RED) {
stack[ht - 2]->color = RED;
stack[ht - 1]->color = yPtr->color = BLACK;
ht = ht -2;
} else {
if (dir[ht - 1] == 0) {
yPtr = stack[ht - 1];
} else {
xPtr = stack[ht - 1];
yPtr = xPtr->link[1];
yPtr->link[0]->link[2]=xPtr;
xPtr->link[1] = yPtr->link[0];
yPtr->link[0] = xPtr;
stack[ht - 2]->link[0] = yPtr;
zptr=xPtr->link[2];
xPtr->link[2]=yPtr;
yPtr->link[2]=zptr;
}
xPtr = stack[ht - 2];
xPtr->color = RED;
yPtr->color = BLACK;
yPtr->link[0]->link[2]=xPtr;
xPtr->link[0] = yPtr->link[1];
zptr=xPtr->link[2];
yPtr->link[1] = xPtr;
xPtr->link[2]=yPtr;
if (xPtr == root) {
root = yPtr;
yPtr->link[2]=NULL;
} else {
stack[ht - 3]->link[dir[ht - 3]] = yPtr;
yPtr->link[2]=zptr;
}
break;
}
} else {
yPtr = stack[ht - 2]->link[0];
if ((yPtr != NULL) && (yPtr->color == RED)) {
stack[ht - 2]->color = RED;
stack[ht - 1]->color = yPtr->color = BLACK;
ht = ht - 2;
} else {
if (dir[ht - 1] == 1) {
yPtr = stack[ht - 1];
} else {
xPtr = stack[ht - 1];
yPtr = xPtr->link[0];
yPtr->link[0]->link[2]=xPtr;
xPtr->link[0] = yPtr->link[1];
zptr=xPtr->link[2];
yPtr->link[1] = xPtr;
xPtr->link[2]=yPtr;
yPtr->link[2]=zptr;
stack[ht - 2]->link[1] = yPtr;
}
xPtr = stack[ht - 2];
yPtr->color = BLACK;
xPtr->color = RED;
yPtr->link[0]->link[2]=xPtr;
xPtr->link[1] = yPtr->link[0];
zptr=xPtr->link[2];
yPtr->link[0] = xPtr;
xPtr->link[2]=yPtr;
if (xPtr == root) {
root = yPtr;
yPtr->link[2]=NULL;
} else {
stack[ht - 3]->link[dir[ht - 3]] = yPtr;
yPtr->link[2]=zptr;
}
break;
}
}
}
root->color = BLACK;
}
void print(struct rbNode * root)
{
if (root != NULL)
{
print(root->link[0]);
printf("%d %s ", root
->data
, root
->color
); if (root->link[2] == NULL)
{
}
else
{
printf("%d\n", (root
->link
[2])->data
); }
print(root->link[1]);
}
return;
}
int main() {
int n,i;
int a=n;
int ar[n];
for (i=0;i<a;i++){
insertion(ar[i]);
}
print(root);
return 0;
}
  #include <stdio.h>
  #include <stdlib.h>
  
  enum nodeColor {
        RED,
        BLACK
  };

  struct rbNode {
        int data, color;
        struct rbNode *link[3];
  };

  struct rbNode *root = NULL;

  struct rbNode * createNode(int data) {
        struct rbNode *newnode;
        newnode = (struct rbNode *)malloc(sizeof(struct rbNode));
        newnode->data = data;
        newnode->color = RED;
        newnode->link[0] = newnode->link[1]=newnode->link[2] = NULL;
        return newnode;
  }

  void insertion (int data) {
        struct rbNode *stack[98],*zptr, *ptr, *newnode, *xPtr, *yPtr,*a;
        int dir[98], ht = 0, index;
        ptr = root;
        if (!root) {
                root = createNode(data);
                return;
        }
        stack[ht] = root;
        dir[ht++] = 0;
        /* find the place to insert the new node */
        while (ptr != NULL) {
                if (ptr->data == data) {
                        printf("Duplicates Not Allowed!!\n");
                        return;
                }
                index = (data - ptr->data) > 0 ? 1 : 0;
                a=ptr->data;
                stack[ht] = ptr;
                ptr = ptr->link[index];
                ptr->link[2]=a;
                dir[ht++] = index;

        }
        /* insert the new node */
        stack[ht - 1]->link[index] = newnode = createNode(data);
        while ((ht >= 3) && (stack[ht - 1]->color == RED)) {
                if (dir[ht - 2] == 0) {
                        yPtr = stack[ht - 2]->link[1];
                        if (yPtr != NULL && yPtr->color == RED) {
                                
                                stack[ht - 2]->color = RED;
                                stack[ht - 1]->color = yPtr->color = BLACK;
                                ht = ht -2;
                        } else {
                                if (dir[ht - 1] == 0) {
                                        yPtr = stack[ht - 1];
                                } else {
                                        
                                        xPtr = stack[ht - 1];
                                        yPtr = xPtr->link[1];
                                        yPtr->link[0]->link[2]=xPtr;
                                        xPtr->link[1] = yPtr->link[0];
                                        yPtr->link[0] = xPtr;
                                        stack[ht - 2]->link[0] = yPtr;
                                        zptr=xPtr->link[2];
                                        xPtr->link[2]=yPtr;
                                        yPtr->link[2]=zptr;
                                }
                               
                                xPtr = stack[ht - 2];
                                xPtr->color = RED;
                                yPtr->color = BLACK;
                                yPtr->link[0]->link[2]=xPtr;
                                xPtr->link[0] = yPtr->link[1];
                                zptr=xPtr->link[2];
                                yPtr->link[1] = xPtr;
                                xPtr->link[2]=yPtr;
                                if (xPtr == root) {
                                        root = yPtr;
                                        yPtr->link[2]=NULL;
                                } else {
                                        stack[ht - 3]->link[dir[ht - 3]] = yPtr;
                                        yPtr->link[2]=zptr;
                                }
                                break;
                        }
                } else {
                        yPtr = stack[ht - 2]->link[0];
                        if ((yPtr != NULL) && (yPtr->color == RED)) {
                                stack[ht - 2]->color = RED;
                                stack[ht - 1]->color = yPtr->color = BLACK;
                                ht = ht - 2;
                        } else {
                                if (dir[ht - 1] == 1) {
                                        yPtr = stack[ht - 1];
                                } else {

                                        xPtr = stack[ht - 1];
                                        yPtr = xPtr->link[0];
                                        yPtr->link[0]->link[2]=xPtr;
                                        xPtr->link[0] = yPtr->link[1];
                                        zptr=xPtr->link[2];
                                        yPtr->link[1] = xPtr;
                                        xPtr->link[2]=yPtr;
                                        yPtr->link[2]=zptr;
                                        stack[ht - 2]->link[1] = yPtr;
                                }
                                
                                xPtr = stack[ht - 2];
                                yPtr->color = BLACK;
                                xPtr->color = RED;
                                yPtr->link[0]->link[2]=xPtr;

                                xPtr->link[1] = yPtr->link[0];
                                zptr=xPtr->link[2];

                                yPtr->link[0] = xPtr;
                                xPtr->link[2]=yPtr;

                                if (xPtr == root) {
                                        root = yPtr;
                                        yPtr->link[2]=NULL;
                                } else {
                                        stack[ht - 3]->link[dir[ht - 3]] = yPtr;
                                        yPtr->link[2]=zptr;
                                }
                                break;
                        }
                }
        }
        root->color = BLACK;
  }

  void print(struct rbNode * root)
  {
  		if (root != NULL)
  		{
  			print(root->link[0]);
  			printf("%d %s ", root->data, root->color);
  			if (root->link[2] == NULL)
  			{
  				printf("NIL\n");
  			}
  			else
  			{
  				printf("%d\n", (root->link[2])->data);
  			}
  			print(root->link[1]);
  		}
  		return;
  }

  int main() {
	int n,i;
	scanf("%d",&n);
	int a=n;
	int ar[n];
	for (i=0;i<a;i++){
		scanf("%d",&ar[i]);
		insertion(ar[i]);
	}
		
	print(root);
	return 0;

}
