#include <stdlib.h>
#include <stdio.h>
struct node{
int val;
struct node *next;
struct node *prev;
struct tree *prev_tree;
};
struct tree{
int val;
struct tree *l;
struct tree *r;
struct tree *p;
struct node *next;
struct node *prev;
};
int cmp(struct tree* A, struct tree* B)//Function to cmp two arbitrary large numbers
{
struct node *tree1=NULL;
struct node *tree2=NULL;
int i=0;
tree1
=(struct node
*)malloc(sizeof(struct node
)); tree1=A->next;
tree2
=(struct node
*)malloc(sizeof(struct node
)); tree2=B->next;
if(tree1!=NULL&&tree2!=NULL)
{
while(tree1->next!=NULL)
{
tree1=tree1->next;
}
while(tree2->next!=NULL)
{
tree2=tree2->next;
}
while(tree1->prev!=NULL&&tree2->prev!=NULL)
{
tree1=tree1->prev;
tree2=tree2->prev;
}
if(tree1->prev==NULL&&tree2->prev!=NULL)
{
tree2=tree2->prev;
}
if(tree2->prev==NULL&&tree1->prev!=NULL)
{
tree1=tree1->prev;
}
if(tree1->prev==NULL&&tree2->prev!=NULL)
{
return 0;
}
if(tree2->prev==NULL&&tree1->prev!=NULL)
{
return 1;
}
while(tree1!=NULL||tree2!=NULL)
{
if(i==0)
{
if(A->val>B->val)
{
return 1;
}
if(B->val>A->val)
{
return 0;
}
tree1=A->next;
tree2=B->next;
i++;
continue;
}
if(tree1->val>tree2->val)
{
return 1;
}
if(tree2->val>tree1->val)
{
return 0;
}
tree1=tree1->next;
tree2=tree2->next;
}
}
else
{
if(A->val>B->val)
{
return 1;
}
if(B->val>A->val)
{
return 0;
}
}
return 2;
}
struct tree* p(struct tree *A, struct tree *B)//Gives the p of new node to be inserted
{
struct tree* n=NULL;
n
=(struct tree
*)malloc(sizeof(struct tree
)); while(B!=NULL)
{
if(cmp(A,B)==1)
{
n=B;
B=B->r;
continue;
}
if(cmp(A,B)==0)
{
n=B;
B=B->l;
continue;
}
}
return n;
}
struct tree* n_tree(int val)
{
struct tree *n;
n
=(struct tree
*)malloc(sizeof(struct tree
)); n->val=val;
n->l=NULL;
n->r=NULL;
n->prev=NULL;
n->next=NULL;
n->p=NULL;
return n;
}
void preorder(struct tree* node)
{
if(node == NULL)
{
return;
}
preorder(node->l);
preorder(node->r);
}
struct node* n_node(int val, struct node *a)
{
struct node *n;
n
=(struct node
*)malloc(sizeof(struct node
)); n->val=val;
n->prev=a;
if(a!=NULL)
{
a->next=n;
}
n->next=NULL;
n->prev_tree=NULL;
return n;
}
struct node* head(int val)
{
struct node *n;
n
=(struct node
*)malloc(sizeof(struct node
)); n->next=NULL;
n->prev=NULL;
n->prev_tree=NULL;
n->val=val;
return n;
}
void pos(struct tree *t, struct tree *root)
{
while(root!=NULL)
{
if(cmp(t,root)==2)
{
break;
}
if(cmp(t,root)==1)
{
root=root->r;
continue;
}
root=root->l;
}
return;
}
int main()
{
int c_1,c_2,c_3,f1=0,f2=0,f3=0,f4=0,i=0,j=0,k=0,m=1;
struct tree *root=NULL;
struct node *tree1=NULL;
struct tree *tree2=NULL;
struct node *temp_1=NULL;
struct tree *temp_2=NULL;
struct tree *p_node=NULL;
p_node
=(struct tree
*)malloc(sizeof(struct tree
)); temp_2
=(struct tree
*)malloc(sizeof(struct tree
)); temp_1
=(struct node
*)malloc(sizeof(struct node
)); tree1
=(struct node
*)malloc(sizeof(struct node
)); tree2
=(struct tree
*)malloc(sizeof(struct tree
)); root
=(struct tree
*)malloc(sizeof(struct tree
)); root->val=-2;
root->p=NULL;
root->l=NULL;
root->r=NULL;
root->prev=NULL;
root->next=NULL;
while((c_1
=fgetc(stdin
))!=EOF
) {
if(c_1=='N')
{
c_2=c_1;
continue;
}
else if(c_1=='S')
{
c_2=c_1;
continue;
}
else if(c_1=='P')
{
c_2=c_1;
continue;
}
else if((c_1==' ')&&(c_2=='N')&&(f1==0))
{
f1=1;
continue;
}
else if((c_1==' ')&&(c_2=='S')&&(f2==0))
{
f2=1;
continue;
}
else if((c_1==' ')&&(c_2=='P')&&(f3==0))
{
f3=1;
continue;
}
else if(f1==1)
{
if(i==0)
{
root->val=c_1-'0';
tree2=root;
i++;
continue;
}
if(c_1!=' '&&c_1!='\n')
{
if(i==1)
{
tree1=n_node(c_1-'0',NULL);
tree1->prev_tree=root;
root->next=tree1;
temp_1=tree1;
i=i+3;
tree2=root;
continue;
}
if(i==2)
{
tree2=n_tree(c_1-'0');
i++;
continue;
}
if(i==3)
{
tree1=n_node(c_1-'0',NULL);
tree1->prev_tree=tree2;
tree2->next=tree1;
temp_1=tree1;
i++;
continue;
}
tree1=n_node(c_1-'0',tree1);
continue;
}
if(c_1==' ')
{
if(k==0)
i=2;
k++;
continue;
}
p_node=p(tree2,root);
tree2->p=p_node;
if(cmp(tree2,p_node)==1)
{
p_node->r=tree2;
}
if(cmp(tree2,p_node)==0)
{
p_node->l=tree2;
}
i=2;
continue;
}
if(c_1=='\n')
{
p_node=p(tree2,root);
tree2->p=p_node;
if(cmp(tree2,p_node)==1)
{
p_node->r=tree2;
}
if(cmp(tree2,p_node)==0)
{
p_node->l=tree2;
}
f1=0;
continue;
}
}
else if(f2==1)
{
if(j==0)
{
temp_2=n_tree(c_1-'0');
j++;
continue;
}
if(c_1=='\n')
{
pos(temp_2, root);
break;
}
if(m==1)
{
tree1=n_node(c_1-'0',NULL);
tree1->prev_tree=temp_2;
temp_2->next=tree1;
m++;
continue;
}
tree1=n_node(c_1-'0',tree1);
}
}
return 0;
}
#include <stdlib.h>
#include <stdio.h>
struct node{
    int val;
    struct node *next;
    struct node *prev;
    struct tree *prev_tree;
};
struct tree{
    int val;
    struct tree *l;
    struct tree *r;
    struct tree *p;
    struct node *next;
    struct node *prev;
};
int cmp(struct tree* A, struct tree* B)//Function to cmp two arbitrary large numbers
{   
    struct node *tree1=NULL;
    struct node *tree2=NULL;
    int i=0;
    tree1=(struct node *)malloc(sizeof(struct node)); 
    tree1=A->next;
    tree2=(struct node *)malloc(sizeof(struct node));
    tree2=B->next;
    if(tree1!=NULL&&tree2!=NULL)
    {
        while(tree1->next!=NULL)
        {
            tree1=tree1->next;
        }
        while(tree2->next!=NULL)
        {
            tree2=tree2->next;
        }
        while(tree1->prev!=NULL&&tree2->prev!=NULL)
        {
            tree1=tree1->prev;
            tree2=tree2->prev;
        }
        if(tree1->prev==NULL&&tree2->prev!=NULL)
        {
            tree2=tree2->prev;
        }
        if(tree2->prev==NULL&&tree1->prev!=NULL)
        {   
            tree1=tree1->prev;
        }
        if(tree1->prev==NULL&&tree2->prev!=NULL)
        {
            return 0;
        }
        if(tree2->prev==NULL&&tree1->prev!=NULL)
        {
            return 1;
        }
        while(tree1!=NULL||tree2!=NULL)
        {   
            if(i==0)
            {   
                if(A->val>B->val)
                {
                    return 1;
                }
                if(B->val>A->val)
                {
                    return 0;
                }
                tree1=A->next;
                tree2=B->next;
                i++;
                continue;
            }
            if(tree1->val>tree2->val)
            {
                return 1;
            }
            if(tree2->val>tree1->val)
            {
                return 0;
            }
            tree1=tree1->next;
            tree2=tree2->next;
        }
        
    }
    else
    {
        if(A->val>B->val)
        {
            return 1;
        }
        if(B->val>A->val)
        {
            return 0;
        }
    }
    return 2;
}
struct tree* p(struct tree *A, struct tree *B)//Gives the p of new node to be inserted
{   
    struct tree* n=NULL;
    n=(struct tree *)malloc(sizeof(struct tree));
    while(B!=NULL)
    {
        if(cmp(A,B)==1)
        {   
            n=B;
            B=B->r;
            continue;
        }
        if(cmp(A,B)==0)
        {
            n=B;
            B=B->l;
            continue;
        }
    }   
    return n;
}
struct tree* n_tree(int val)
{
    struct tree *n;
    n=(struct tree *)malloc(sizeof(struct tree));
    n->val=val;
    n->l=NULL;
    n->r=NULL;
    n->prev=NULL;
    n->next=NULL;
    n->p=NULL;
    return n;
}
void preorder(struct tree* node) 
{ 
    if(node == NULL) 
    {
        return; 
    }
    printf("%d", node->val);   
    preorder(node->l); 
    preorder(node->r); 
} 
struct node* n_node(int val, struct node *a)
{
    struct node *n;
    n=(struct node *)malloc(sizeof(struct node));
    n->val=val;
    n->prev=a;
    if(a!=NULL)
    {
        a->next=n;
    }
    n->next=NULL;
    n->prev_tree=NULL;
    return n;
}
struct node* head(int val)
{
    struct node *n;
    n=(struct node *)malloc(sizeof(struct node));
    n->next=NULL;
    n->prev=NULL;
    n->prev_tree=NULL;
    n->val=val;
    return n;
}
void pos(struct tree *t, struct tree *root)
{
    while(root!=NULL)
    {
        if(cmp(t,root)==2)
        {
            printf("\n");
            break;
        }
        if(cmp(t,root)==1)
        {
            root=root->r;
            printf("1");
            continue;       
        }
        root=root->l;
        printf("0");
    }
    return;
}
int main()
{
    int c_1,c_2,c_3,f1=0,f2=0,f3=0,f4=0,i=0,j=0,k=0,m=1;
    struct tree *root=NULL;
    struct node *tree1=NULL;
    struct tree *tree2=NULL;
    struct node *temp_1=NULL;
    struct tree *temp_2=NULL;
    struct tree *p_node=NULL;
    p_node=(struct tree *)malloc(sizeof(struct tree));
    temp_2=(struct tree *)malloc(sizeof(struct tree));
    temp_1=(struct node *)malloc(sizeof(struct node));
    tree1=(struct node *)malloc(sizeof(struct node));
    tree2=(struct tree *)malloc(sizeof(struct tree));   
    root=(struct tree *)malloc(sizeof(struct tree));
    root->val=-2;
    root->p=NULL;
    root->l=NULL;
    root->r=NULL;
    root->prev=NULL;
    root->next=NULL;
    while((c_1=fgetc(stdin))!=EOF)
    {
        if(c_1=='N')
        {
            c_2=c_1;
            continue;   
        }
        else if(c_1=='S')
        {       
            c_2=c_1;
            continue;
        }
        else if(c_1=='P')
        {
            c_2=c_1;
            continue;
        }
        else if((c_1==' ')&&(c_2=='N')&&(f1==0))
        {   
            f1=1;
            continue;
        }
        else if((c_1==' ')&&(c_2=='S')&&(f2==0))
        {   
            f2=1;
            continue;
        }
        else if((c_1==' ')&&(c_2=='P')&&(f3==0))
        {
            f3=1;
            continue;
        }
        else if(f1==1)
        {
            if(i==0)
            {   
                root->val=c_1-'0';
                tree2=root;               
                i++;
                printf("%d",root->val);
                continue;
            }
            if(c_1!=' '&&c_1!='\n')
            {
                if(i==1)
                {
                    tree1=n_node(c_1-'0',NULL);
                    tree1->prev_tree=root;
                    root->next=tree1;
                    temp_1=tree1;
                    printf("%d",tree1->val);
                    i=i+3;
                    tree2=root;
                    continue;
                }
                if(i==2)
                {   
                    tree2=n_tree(c_1-'0');
                    printf("%d",tree2->val);
                    i++;
                    continue;
                }
                if(i==3)
                {
                    tree1=n_node(c_1-'0',NULL);
                    tree1->prev_tree=tree2;
                    tree2->next=tree1;
                    temp_1=tree1;
                    printf("%d",tree1->val);
                    i++;
                    continue;
                }
                tree1=n_node(c_1-'0',tree1);
                printf("%d",tree1->val); 
                continue;
            }
            if(c_1==' ')
            {
                if(k==0)
                {   printf(" ");
                    i=2;
                    k++;
                    continue;
                }
                p_node=p(tree2,root);
                printf(" %d ",p_node->val);
                tree2->p=p_node;
                if(cmp(tree2,p_node)==1)
                {
                    p_node->r=tree2;
                }
                if(cmp(tree2,p_node)==0)
                {
                    p_node->l=tree2;
                }
                i=2;
                continue;
                    
            }
            if(c_1=='\n')
            {   
                p_node=p(tree2,root);
                printf(" %d ",p_node->val);                
                tree2->p=p_node;
                if(cmp(tree2,p_node)==1)
                {
                    p_node->r=tree2;
                }
                if(cmp(tree2,p_node)==0)
                {
                    p_node->l=tree2;
                }
                f1=0;
                continue;
            }       
        }
        else if(f2==1)
        {   
            if(j==0)
            {   
                temp_2=n_tree(c_1-'0');
                printf("%d",temp_2->val);
                j++;
                continue;
            }
            if(c_1=='\n')
            {                       
                pos(temp_2, root);
                break;
            }
            if(m==1)
            {
                tree1=n_node(c_1-'0',NULL);
                tree1->prev_tree=temp_2;
                temp_2->next=tree1;
                printf("%d",tree1->val);
                m++;
                continue;
            }
            tree1=n_node(c_1-'0',tree1);
            printf("%d",tree1->val);            
        }               
    }
    return 0;
}