#include<stdio.h>
#include<stdlib.h>
/* A binary tree node has data, pointer to left child
and a pointer to right child */
struct node
{
int data;
struct node* left;
struct node* right;
};
struct node* newNode(int data)
{
struct node
* node
= (struct node
*) malloc(sizeof(struct node
)); node->data = data;
node->left = NULL;
node->right = NULL;
return(node);
}
void mirror(struct node* node)
{
if (node==NULL)
return;
else
{
struct node* temp;
mirror(node->left);
mirror(node->right);
temp = node->left;
node->left = node->right;
node->right = temp;
}
}
void inOrder(struct node* node)
{
if (node == NULL)
return;
inOrder(node->left);
inOrder(node->right);
}
/* Driver program to test mirror() */
int main()
{
struct node *root = newNode(1);
root->left = newNode(2);
root->right = newNode(3);
root->left->left = newNode(4);
root->left->right = newNode(5);
printf("\n Inorder traversal of the constructed tree is \n"); inOrder(root);
mirror(root);
printf("\n Inorder traversal of the mirror tree is \n"); inOrder(root);
return 0;
}
I2luY2x1ZGU8c3RkaW8uaD4KI2luY2x1ZGU8c3RkbGliLmg+CiAKLyogQSBiaW5hcnkgdHJlZSBub2RlIGhhcyBkYXRhLCBwb2ludGVyIHRvIGxlZnQgY2hpbGQgCiAgIGFuZCBhIHBvaW50ZXIgdG8gcmlnaHQgY2hpbGQgKi8Kc3RydWN0IG5vZGUgCnsKICAgIGludCBkYXRhOwogICAgc3RydWN0IG5vZGUqIGxlZnQ7CiAgICBzdHJ1Y3Qgbm9kZSogcmlnaHQ7Cn07CiAKc3RydWN0IG5vZGUqIG5ld05vZGUoaW50IGRhdGEpCiAKewogIHN0cnVjdCBub2RlKiBub2RlID0gKHN0cnVjdCBub2RlKikgbWFsbG9jKHNpemVvZihzdHJ1Y3Qgbm9kZSkpOwogIG5vZGUtPmRhdGEgPSBkYXRhOwogIG5vZGUtPmxlZnQgPSBOVUxMOwogIG5vZGUtPnJpZ2h0ID0gTlVMTDsKICAgCiAgcmV0dXJuKG5vZGUpOwp9CiAKIAoKdm9pZCBtaXJyb3Ioc3RydWN0IG5vZGUqIG5vZGUpIAp7CiAgaWYgKG5vZGU9PU5VTEwpIAogICAgcmV0dXJuOyAgCiAgZWxzZQogIHsKCiAgICBzdHJ1Y3Qgbm9kZSogdGVtcDsKICAgIG1pcnJvcihub2RlLT5sZWZ0KTsKICAgIG1pcnJvcihub2RlLT5yaWdodCk7CgogICAgdGVtcCAgICAgICAgPSBub2RlLT5sZWZ0OwogICAgbm9kZS0+bGVmdCAgPSBub2RlLT5yaWdodDsKICAgIG5vZGUtPnJpZ2h0ID0gdGVtcDsKICAgIAogIH0KfSAKIAogCnZvaWQgaW5PcmRlcihzdHJ1Y3Qgbm9kZSogbm9kZSkgCnsKICBpZiAobm9kZSA9PSBOVUxMKSAKICAgIHJldHVybjsKICAgCiAgcHJpbnRmKCIlZCAiLCBub2RlLT5kYXRhKTsgCiAgaW5PcmRlcihub2RlLT5sZWZ0KTsKICBpbk9yZGVyKG5vZGUtPnJpZ2h0KTsKfSAgCiAKIAovKiBEcml2ZXIgcHJvZ3JhbSB0byB0ZXN0IG1pcnJvcigpICovCmludCBtYWluKCkKewogIHN0cnVjdCBub2RlICpyb290ID0gbmV3Tm9kZSgxKTsKICByb290LT5sZWZ0ICAgICAgICA9IG5ld05vZGUoMik7CiAgcm9vdC0+cmlnaHQgICAgICAgPSBuZXdOb2RlKDMpOwogIHJvb3QtPmxlZnQtPmxlZnQgID0gbmV3Tm9kZSg0KTsKICByb290LT5sZWZ0LT5yaWdodCA9IG5ld05vZGUoNSk7IAogICAKICBwcmludGYoIlxuIElub3JkZXIgdHJhdmVyc2FsIG9mIHRoZSBjb25zdHJ1Y3RlZCB0cmVlIGlzIFxuIik7CiAgaW5PcmRlcihyb290KTsKICBtaXJyb3Iocm9vdCk7IAogIHByaW50ZigiXG4gSW5vcmRlciB0cmF2ZXJzYWwgb2YgdGhlIG1pcnJvciB0cmVlIGlzIFxuIik7ICAKICBpbk9yZGVyKHJvb3QpOwogICAKICBnZXRjaGFyKCk7CiAgcmV0dXJuIDA7ICAKfQo=