Упражнения на Java: Получить обход по значениям его узлов для заданного двоичного дерева.
Java Basic: упражнение-126 с решением
Напишите Java-программу для получения обхода значений ее узлов заданного двоичного дерева.
Пример: {10, 20, 30, 40, 50}
Выход: 40 20 50 10 30
Образец бинарного дерева
Inorder Traversal:
Пример решения:
Java-код:
class Node
{
int key;
Node left, right;
public Node(int item)
{
key = item;
left = right = null;
}
}
class BinaryTree
{
// Root of Binary Tree
Node root;
BinaryTree()
{
root = null;
}
// Print the nodes of binary tree in inorder
void print_Inorder(Node node)
{
if (node == null)
return;
print_Inorder(node.left);
// Print the data of node
System.out.print(node.key + " ");
print_Inorder(node.right);
}
void print_Inorder()
{
print_Inorder(root);
}
public static void main(String[] args)
{
BinaryTree tree = new BinaryTree();
tree.root = new Node(55);
tree.root.left = new Node(21);
tree.root.right = new Node(80);
tree.root.left.left = new Node(9);
tree.root.left.right = new Node(29);
tree.root.right.left = new Node(76);
tree.root.right.right = new Node(91);
System.out.println("\nInorder traversal of binary tree is: ");
tree.print_Inorder();
}
}
Пример вывода:
Обход по бинарному дереву: 9 21 29 55 76 80 91
Блок - схема:
Редактор кода Java:
Внесите свой код и комментарии через Disqus.
Предыдущий: Напишите программу Java, чтобы получить предварительный обход значений ее узлов данного двоичного дерева.
Далее: Напишите Java-программу для получения обхода Postorder значений его узлов заданного двоичного дерева.
Каков уровень сложности этого упражнения?
Новый контент: Composer: менеджер зависимостей для PHP , R программирования
disqus2code