|
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 Написал класс узла.
Как реализовать дерево кто подскажет ?
0
|
||||||
| 30.06.2010, 19:03 | |
|
Ответы с готовыми решениями:
20
Бинарное дерево Бинарное дерево Бинарное дерево |
|
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
|
||||||
| 30.06.2010, 19:06 | ||||||
0
|
||||||
|
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
|
|
| 30.06.2010, 19:48 | |
|
Как-то так, надеюсь, не накосячил.
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
|
|
|
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
|
||||||
| 02.07.2010, 01:23 [ТС] | ||||||
|
Я на основе твоего кода писал:
0
|
||||||
|
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
|
||||||
| 02.07.2010, 10:32 | ||||||
|
Пожалуй, опять покритикую.
Во-первых, вполне может оказаться, что root - единственный элемент дерева, и в нем находится нужный ключ, а у тебя в этом случае исключение бросается. Во-вторых, ситуации когда в дереве нет нужного ключа, и когда дерево пустое, ничем принципиально не различаются, не нужно заводить RootNotFoundException, а обрабатывать эти ситуации одинаково - просто нужный элемент не найден. Добавлено через 8 минут Ну у меня бы исправление вот так выглядело:
0
|
||||||
|
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 | ||||||
Добавлено через 1 час 17 минут Насчет второго - думаю, выкидывание исключения - тоже допустимый вариант. Я имел в виду другое: не следует различать ситуации когда дерево полностью пусто, и когда просто нет нужного элемента. По крайней мере я не вижу в этом смысла.
0
|
||||||
|
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
|
||||||
| 02.07.2010, 21:38 [ТС] | ||||||
|
Можна конечно и не различать эти ситуации, но тогда легче будет разобраться в случае чего. В стандартных классах методы тоже часто выбрасывают по 2-3 разных исключения в разных ситуациях.
Добавлено через 4 часа 47 минут А вот написал я функцию обсчета высоты дерева. Гляньте. Правильно ?
0
|
||||||
|
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
|
|
| 02.07.2010, 22:08 | |
|
Верно.
Добавлено через 27 минут Кстати думаю надо сделать Node внутренним классом Tree. Это и логично (Node без Tree мало смысла имеет), и не придется каждый раз писать Node<Key, Value>.
0
|
|
|
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
|
||||||
| 02.07.2010, 22:15 [ТС] | ||||||
|
Фигню написал, сам понял. Вот что то новое наваял:
0
|
||||||
|
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
|
|
| 02.07.2010, 22:21 | |
|
Где фигня О_о ? Все правильно было.
Добавлено через 25 секунд А сейчас неправильно.
0
|
|
|
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
|
|
|
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
|
|
|
34 / 34 / 10
Регистрация: 11.05.2010
Сообщений: 110
|
|
| 02.07.2010, 22:31 [ТС] | |
|
Ну тогда если я выполнил задание, то я спокоен =)
0
|
|
|
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
|
|
| 08.11.2010, 19:54 | |
|
Помогаю со студенческими работами здесь
20
Распечатать бинарное дерево Бинарное дерево Удаление елемента Коллекция TreeSet и бинарное дерево
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Учёным и волонтёрам проекта «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/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|