/* cs */
class Node {
private int key;
private Node left, right;
public Node(int key) {
this.left = this.right = null;
this.key = key;
}
public static void insertNode(ref Node root, int key) {
if (root == null) {
root = new Node(key);
return;
}
if (key < root.key)
insertNode(ref root.left, key);
else
insertNode(ref root.right, key);
}
public static bool deleteNode(ref Node root, int key) {
if (root == null) return false;
if (key < root.key)
return deleteNode(ref root.left, key);
else if (key > root.key)
return deleteNode(ref root.right, key);
else {
if (root.left == null) {
root = root.right;
} else if (root.right == null) {
root = root.left;
} else { // root.left != null && root.right != null
Node p;
for (p = root.left; p.right != null; p = p.right)
;
p.right = root.right;
root = root.left;
}
}
return true;
}
public void vomitTree(int c) {
if (this.left != null)
this.left.vomitTree(c + 3);
for (int i = 0; i < c; i++) System.Console.Write(' ');
System.Console.WriteLine(this.key);
if (this.right != null)
this.right.vomitTree(c + 3);
}
};
class BinaryTree {
private Node root;
public BinaryTree() { this.root = null; }
public void insertNode(int key) { Node.insertNode(ref this.root, key); }
public bool deleteNode(int key) { return Node.deleteNode(ref this.root, key); }
public void vomitTree() { if (this.root != null) this.root.vomitTree(0); }
};
class Sample{
public static void Main() {
BinaryTree tree = new BinaryTree();
for (;;) {
//System.Console.Write("> ");
int input = int.Parse(System.Console.ReadLine());
if (input < 0)
break;
tree.insertNode(input);
tree.vomitTree();
}
System.Console.WriteLine("deleting.");
for (;;) {
//System.Console.Write("> ");
int input = int.Parse(System.Console.ReadLine());
if (input < 0)
break;
if (tree.deleteNode(input))
System.Console.WriteLine("deleted.");
else
System.Console.WriteLine("not found.");
tree.vomitTree();
}
}
}
/* end */