Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
0 / 0 / 0
Регистрация: 23.10.2019
Сообщений: 1

 Идеально сбалансированное бинарное дерево

25.05.2020, 13:18. Показов 2251. Ответов 1

Студворк — интернет-сервис помощи студентам
Доброго времени суток, господа! Слезливо прошу о помощи, так как сроки уже горят.
Перейдем к теме. Дерево я написал, но не могу понять как его красиво вывести, получается лишь в строчку, начинаю баловаться отступами и выход каша.
Необходимо несколько вариантов вывода:
1. Вывод в прямом порядке
2. Вывод в симметричном порядке
3. Вывод в обратно симметричном порядке
(Прикрепил фото)

Заранее спасибо за ответы!

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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
class TestTree {
    public static void main(String[] args) {
        Tree tree = new Tree(3);
        tree.insert();
        tree.showS();
    }
}
 
class Tree {
    static int count = 0;
    static int size;
    static boolean n = true;
    private Node root;
    
    Tree(int ssize) {
        size = ssize;
        root = new Node();
    }
    static class Node {
        int key;
        Node left;
        Node right;
        int count = 0;
        
        
        Node() {
                int y =(int) (Math.random() * 100);
                key = y;
        }
    }
    
    
    public void insert() {
        
        root = doInsert(root);
    }
 
    private static Node doInsert(Node node) {
        if(count<size) {
            count++;
        if(n) {
            Node nodeL = new Node();
            Node nodeR = new Node();
            node.left = doInsert(nodeL);
            node.right = doInsert(nodeR);
        }
        } else { n = false;}
        return node;
    }
    int sh = 0;
    boolean na = true;
    public void showS(){
        int lvl = 1;
        System.out.println(root.key);
        traverseInOrder(root);
        
    }
    public void traverseInOrder(Node node) {
    if (node.left != null&&node.right != null) {
        
        for(int i =0;i<lvl;i++) {
        System.out.print("  ");
        }
        
 
        lvl++;
        System.out.println("   " + node.left.key);
        traverseInOrder(node.left);
        System.out.println("   " + node.right.key);
        traverseInOrder(node.right);
        
    }
}
}
Миниатюры
 Идеально сбалансированное бинарное дерево  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.05.2020, 13:18
Ответы с готовыми решениями:

Сбалансированное дерево
Дерево называется сбалансированным, если для любой его вершины высота левого и правого поддерева для этой вершины различаются не более чем...

Бинарное дерево
Задание: Implement Binary Tree and write unit tests for the class. Use JUnit to create tests. Please, implement next methods: 1. ...

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

1
25 / 21 / 6
Регистрация: 10.12.2018
Сообщений: 115
11.06.2020, 22:45
я бы использовал очередь для обхода. получаем первый элемент пушш в очередь делаем пулл выводим его на печать, и проверяем есть ли у элемента ссылки left и right. если есть. то. пихаем в очередь. делаем пулл. выводим на печать проверяем есть ли у элемента ссылки все происодит в цикле do while. проверяем если очередь не пуста продолжаем
вывод будет в порядке. 10, 15 9 13 22. 5 17
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.06.2020, 22:45
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды "Заполнить" и "Очистить" на форме документа
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". На примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных выбран регистр накопления, в. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru