С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.58/72: Рейтинг темы: голосов - 72, средняя оценка - 4.58
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110

Бинарное дерево

30.06.2010, 19:03. Показов 15027. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание: Implement Binary Tree and write unit tests for the class. Use JUnit to create tests.
Please, implement next methods:

1. Insert nodes into a tree. After nodes are inserted, tree should still be binary.

2. Calculate the height of the tree

Prerequisites:

1. Binary Tree can't be empty - at least, it should contain one node (root node)

2. Implementation should conform to all constraints of Binary Tree

Написал класс
узла.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package tree;
 
public class Node {
    private String key;
    private int value;
    private Node left, right;
 
    public Node(String key, int value) {
    this.key = key;
    this.value = value;
    }
    public String getKey() {
        return key;
    }
    public void setKey(String k) {
        key = k;
    }
    public int getValue() {
        return value;
    }
    public void setValue(int v) {
        value = v;
    }
    public void addChild(Node c)
    throws NodeFullException {
        if(left != null && right != null) throw new NodeFullException();
        
        if(left == null) 
            left = c;
        else
        if(right == null)
            right = c;
    }
    public void addChild(Node c, Side side)
    throws UnknownSideException, NodeFullException {
        if(side == Side.Left) {
            if(left != null) throw new NodeFullException();
            left = c;
        }
        else
        if(side == Side.Right) {
            if(right != null) throw new NodeFullException();
            right = c;
        }
        else
            throw new UnknownSideException();
    }
    public void releaseChild(Side side)throws UnknownSideException {
        if(side == Side.Left)
            left = null;
        else
        if(side == Side.Right)
            right = null;
        else
            throw new UnknownSideException();
    }
}

Как реализовать дерево кто подскажет ?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.06.2010, 19:03
Ответы с готовыми решениями:

Бинарное дерево
Приветствую всех! Помогите, пожалуйста, разобрать, есть вот такая задача: "Разработка класса для представления упорядоченного...

Бинарное дерево
Здравствуйте, в общем я написал программу которая строит бинарное дерево, но я не могу придумать как найти пути минимальной длинны между...

Бинарное дерево
Добрый день. Пишу аналог бинарного дерева, вот кусок кода public class Tree<T extends Comparable<T>> { private...

20
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
30.06.2010, 19:06
Java
1
2
3
4
5
6
7
8
9
10
        public void addChild(Node c)
        throws NodeFullException {
                if(left != null && right != null) throw new NodeFullException();
                
                if(left == null) 
                        left = c;
                else
                if(right == null)
                        right = c;
        }
Неправильно. Ща напишу чего-нить, а вы качните-ка Кормена. Уж точно не помешает.
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
30.06.2010, 19:48
Как-то так, надеюсь, не накосячил.
Вложения
Тип файла: rar default package.rar (820 байт, 442 просмотров)
1
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
30.06.2010, 19:55
1. Binary Tree can't be empty - at least, it should contain one node (root node)
По-моему чушь.
Ссылка-то на него всегда есть, но самого root node может и не быть.
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 00:21
Накосячил. Если из пустого дерева попытаться взять - зафейлится.
0
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 01:23  [ТС]
Я на основе твоего кода писал:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public Value get(Key k) 
    throws IllegalStateException,RootNotFoundException  {
        if(this.root == null || (root.left == null && root.right == null)) throw new RootNotFoundException();
        Node<Key, Value> node = this.root;
        while(!k.equals(node.key)) {
            if(k.compareTo(node.key) < 0) {
                if(node.left == null)
                    throw new IllegalStateException("Cannot find key " + k);
                node = node.left;
            }
            else {
                if(node.right == null) {
                    throw new IllegalStateException("Cannot find key " + k);
                }
            node = node.right;
            }
        }
        return node.value;
    }
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 10:32
Пожалуй, опять покритикую.
Во-первых, вполне может оказаться, что root - единственный элемент дерева, и в нем находится нужный ключ, а у тебя в этом случае исключение бросается.
Во-вторых, ситуации когда в дереве нет нужного ключа, и когда дерево пустое, ничем принципиально не различаются, не нужно заводить RootNotFoundException, а обрабатывать эти ситуации одинаково - просто нужный элемент не найден.

Добавлено через 8 минут
Ну у меня бы исправление вот так выглядело:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
    public Value get(Key key) {
        if(root == null)
            return null;
        Node<Key, Value> x = root;
        while (!key.equals(x.key)) {
            if (key.compareTo(x.key) < 0) {
                if (x.left == null) {
                    return null;
                }
                x = x.left;
            } else {
                if (x.right == null) {
                    return null;
                }
                x = x.right;
            }
        }
        return x.val;
    }
}
0
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 15:00  [ТС]
Если root - единственный элемент дерева, то исключения не будет, поскольку root не будет равен null.
Насчет второго согласен, можна порсто null возвращать.
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 16:22
Java
1
if(this.root == null || (root.left == null && root.right == null)) throw new RootNotFoundException();
Ну вот же у тебя исключение выкидывается.

Добавлено через 1 час 17 минут
Насчет второго - думаю, выкидывание исключения - тоже допустимый вариант. Я имел в виду другое: не следует различать ситуации когда дерево полностью пусто, и когда просто нет нужного элемента. По крайней мере я не вижу в этом смысла.
0
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 21:38  [ТС]
Можна конечно и не различать эти ситуации, но тогда легче будет разобраться в случае чего. В стандартных классах методы тоже часто выбрасывают по 2-3 разных исключения в разных ситуациях.

Добавлено через 4 часа 47 минут
А вот написал я функцию обсчета высоты дерева. Гляньте. Правильно ?
Java
1
2
3
4
static int height(Node node) {
        if(node == null) return 0;
        return 1 + Math.max(height(node.left), height(node.right));
    }
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 22:08
Верно.

Добавлено через 27 минут
Кстати думаю надо сделать Node внутренним классом Tree. Это и логично (Node без Tree мало смысла имеет), и не придется каждый раз писать Node<Key, Value>.
0
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 22:15  [ТС]
Фигню написал, сам понял. Вот что то новое наваял:
Java
1
2
3
4
5
6
7
    static int height(Node node) {
        if(node.left != null)
            return 1 + height(node.left);
        if(node.right != null)
            return 1 + height(node.right);
        return 0;
    }
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 22:21
Где фигня О_о ? Все правильно было.

Добавлено через 25 секунд
А сейчас неправильно.
0
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 22:21  [ТС]
Чето у меня походу с пониманием этих деревьев не все в порядке о_О
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 22:22
На бумажке порисуй малямс.

Добавлено через 35 секунд
И да, качни Кормена.
0
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 22:26  [ТС]
Хохол, первая версия считает количество узлов, а мне нужно высоту - т.е. количество "веток", которые соединяют два узла.
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
02.07.2010, 22:29
Количество узлов или количество веток - не принципиально, уж друг по другу их без проблем найдем. Но высота - это длина максимального пути от корня до листьев. Первый твой верно считает - максимальную высоту. А второй - какую-то самую левую высоту.
1
 Аватар для Lendon
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
02.07.2010, 22:31  [ТС]
Ну тогда если я выполнил задание, то я спокоен =)
0
 Аватар для Mazhor1
70 / 43 / 8
Регистрация: 30.10.2009
Сообщений: 101
19.08.2010, 16:41
Уже в глобале работаешь или что-то не правильно сделал?
0
0 / 0 / 0
Регистрация: 27.10.2008
Сообщений: 9
08.11.2010, 19:54
есть у тебя програма которая делает следующее: формирование дерева, вывод элементов дерева, удаление заданных вершин из дерева
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.11.2010, 19:54
Помогаю со студенческими работами здесь

Бинарное дерево поиска
Я написала программу поиска минимума в массиве или среди элементов массива от i до j. В части запросов программа работает правильно, но...

Распечатать бинарное дерево
Всем добрый день! Нужно решить задачу где дыны некоторые целочисленные числа, к примеру 3 5 4 2 8 и надо создать бинарное дерево...

Бинарное дерево Удаление елемента
Как мне реализовать удаление елемента в бинарном дереве? Суть в тексте то понял. Удаление элемента без детей – просто освобождаем память....

Коллекция TreeSet и бинарное дерево
Всех приветствую Вопрос следующий: Как в бинарное дерево попадает число, если TreeSet не использует hashCode() ? На основании чего...

Как реализовать бинарное дерево?
Всем привет. Ребят подскажите как реализовать бинарное дерево (не дерево бинарного поиска, а именно БИНАРНОЕ ДЕРЕВО). Знаю как...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru