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

Поиск точки в бинарном дереве

10.06.2015, 19:41. Показов 535. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как в этот метод добавить условие что если не найдено совпадений то вывести (0,0)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private void contains(Node root, Point point) {     
        if (root != null){ 
            contains(root.left, point);
            if (root.p.equals(point)){
                
                System.out.print(" << " + root.p.x + ", " + root.p.y  + ", " + String.format( "%.2f", root.z ) + " >>");
            }
            else{
                System.out.print(root.toString() + " ");
                
            }           
            contains(root.right, point);
        }       
        
    }
Пробовал вот так но нужно я так понимаю еще ввести изменную чтобы в случае совпадения она например возвращала true но что то пока не могу сделать чтобы работало....
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
    private void contains(Node root, Point point) {
        
        if (root != null){ 
            contains(root.left, point);
            if (root.p.equals(point)){
                
                System.out.print(" << " + root.p.x + ", " + root.p.y  + ", " + String.format( "%.2f", root.z ) + " >>");
            }
            else{
                System.out.print(root.toString() + " ");
                
            }           
            contains(root.right, point);
        }
        else{
            System.out.print("(0,0)");
        }
        
    }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.06.2015, 19:41
Ответы с готовыми решениями:

Поиск максимального суммы значений в бинарном дереве
Есть бинарное дерево, нужно найти максимальную сумму значений в нем. Используя при этом только лишь один цикл и без условий if. У меня...

Рекурсия в бинарном дереве поиска
public boolean add(E e) { if(this.root == null) { this.root = new Node(e, null) ; return true; } else { ...

Дайте источники по реализации remove в бинарном дереве
Через ссылки я всё написал. Задача - написать удаление элемента из дерева, используя реализацию на массивах. А желательно ещё и вставку...

4
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,667
Записей в блоге: 29
10.06.2015, 20:54
Цитата Сообщение от galexik81 Посмотреть сообщение
еще ввести изменную
это что такое? )))
0
2 / 2 / 2
Регистрация: 03.11.2013
Сообщений: 41
10.06.2015, 20:55  [ТС]
variable....разве не так перевел?))))
0
10.06.2015, 21:11

Не по теме:

Изменная -это стиль жизни у жены человека, который часто в командировке)))

0
2 / 2 / 2
Регистрация: 03.11.2013
Сообщений: 41
10.06.2015, 22:38  [ТС]
То есть я так понимаю что условие нужно создать в методе который вызывает contains(Node root, Point point)? и если например нашло то true если же нет то false. Например так
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
    
    /**
     * search for and designate the sought after point in all of the sub trees 
     * Student exercise
     * @param p - the point given to search for
     */
    public void contains(Point point) {
       System.out.print("Searching for:" + point +" in X sub-tree ");
       int found = 0;
       found = containsCheck(overallRoot.xNode, point, found);
       System.out.print("WHEEHAA " + found);
       if (found == 1){
           contains(overallRoot.xNode, point);
       }
       else if (found == 0){
           System.out.print("(0,0)");
       }
       System.out.println();
      /* System.out.print("Searching for:" + point +" in Y sub-tree ");
       contains(overallRoot.yNode, point);
       System.out.println();
       System.out.print("Searching for:" + point +" in Z sub-tree ");
       contains(overallRoot.zNode, point);*/
       
 
    }
    /**
     * This method will traverse through a subtree and print a current node
     * if node point match the given point it will print it as <<point>>
     * @param root current Node to search in
     * @param point given point to search for
     */
    private void contains(Node root, Point point) {
        
        if (root != null){ 
            contains(root.left, point);
            if (root.p.equals(point)){
                
                System.out.print(" << " + root.p.x + ", " + root.p.y  + ", " + String.format( "%.2f", root.z ) + " >>");
            }
            else{
                System.out.print(root.toString() + " ");
                
            }           
            contains(root.right, point);
        }
        
        
    }
    private int containsCheck(Node root, Point point, int found) {
        
        if (root != null){ 
            containsCheck(root.left, point, found);
            if (root.p.equals(point)){
                found = 1;
                System.out.print("<<<<<" + root.toString() + ">>>>>" + " This is f" + found);
                
            }
            else{
                System.out.print(root.toString());
                
                
            }
                    
            containsCheck(root.right, point, found);
            
        }
        
        return found;
    }
    
}
Добавлено через 2 минуты
но все равно не работает....found все равно всегда равно 0.....

Добавлено через 2 минуты
да и тупо получается два раза дерево просматривается первый раз чтобы проверить есть ли такая точка а второй чтобы вывести на экран.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.06.2015, 22:38
Помогаю со студенческими работами здесь

Поиск в бинарном дереве
Не получается организовать поиск в бинарном дереве по значению, а не по ключу. Использую дерево в качестве примера переводчика, то-есть я...

Поиск в бинарном дереве
Привет всем! Нужно написать код, с которым в бинарном дереве можно найти заданное пользователем значение в вершинах и вывести на экран эту...

Поиск в Бинарном Дереве!
Задано бинарное дерево. Определить, есть ли в этом дереве хотя бы два одинаковых элемента. Вывести на экран все одинаковые элементы в...

Поиск в бинарном дереве
Составить рекурсивную функцию для определения первого элемента, у которого совпадают старшая и младшая цифры, в бинарном дереве.

Поиск в ширину на бинарном дереве
Здравствуйте! Моя задача была вывести сотрудников ( которые образуют древовидную структуру ) одного уровня. мой код: --Иерархия...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru