Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.51/35: Рейтинг темы: голосов - 35, средняя оценка - 4.51
43 / 7 / 0
Регистрация: 27.11.2013
Сообщений: 96

Классы и дерево

12.10.2014, 12:54. Показов 7443. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет.
Начал изучать классы, вот тут дерево есть, оцените плиз

Python
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
class Node:
    # Это класс узла.
    def __init__(self, data=u''):
        self.parent = None
        self.children = []
        self.data = data
        
    def add_node(self, data=u''):
        childNode = Node(data)
        childNode.parent = self
        self.children.append(childNode)
        return childNode
 
    def delete_from_tree(self, tree):
        for i in tree.nodes:
            if tree.nodes[i] == self:
                tree.nodes[i] = None
                break
        for child in self.children:
            child.delete_from_tree(tree)
        if self.parent != None:
            self.parent.children.remove(self)
            self.parent = None
        if tree.root == self:
            tree.root = None
 
 
class Tree:
    def __init__(self, rootData=u''):
        self.root = Node(rootData)
        self.nodes = {0: self.root}
        self.lastId = 0
 
    def add_node(self, index, data):
        childNode = self.nodes[index].add_node(data)
        self.lastId += 1
        self.nodes[self.lastId] = childNode
 
    def search(self, data, startNode=None):
        if startNode == None:
            startNode = self.root
        result = []
        if startNode.data == data:
            result.append(startNode)
            
        for i in startNode.children:
            result += self.search(data, i)
        return result
Всё, кажется, понятным, но есть три вопроса, хотелось бы и в них разобраться

1. Как сделать функцию, которая для данного узла возвращает путь от него до корня
2. Как сделать функцию, которая для двух данных узлов возвращает кратчайший (т. е. без повторяющихся узлов) путь от одного узла дерева до другого
3. Как сделать функцию, которая для данного узла возвращает массив всех листьев, достижимых из него

Буду благодарен
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.10.2014, 12:54
Ответы с готовыми решениями:

с++ дерево классы
Написал дерево, но при добавлении нового элемента(add) происходит косяк #ifndef TREEITEM_H #define TREEITEM_H #pragma once ...

Бинарное дерево, классы
Помогите! Мне нужно описать класс, реализующий бинарное дерево, обладающее возможностью добавление новых элементов, удаления существующих,...

Дерево, классы и QAbstractItemModel
Доброго времени. Есть xml файл с вот такой структурой: Корень --Тэг1 ----Тэг2 ------Тэг5 ------Тэг5... ----Тэг3 ...

2
 Аватар для Wolkodav
842 / 480 / 58
Регистрация: 18.09.2012
Сообщений: 1,688
18.10.2014, 00:00
Adastraz,
1) обход в глубину
(2) - (3) - обход в ширину.
0
 Аватар для sigmov
585 / 372 / 63
Регистрация: 22.07.2009
Сообщений: 875
Записей в блоге: 4
19.10.2014, 16:47
Цитата Сообщение от Adastraz Посмотреть сообщение
Всем привет.
Начал изучать классы, вот тут дерево есть, оцените плиз
1. Зачем разделять классы Node и Tree.... Разве поддерево деревом не является!?
2. Множество чилдренов лучше задавать как set, а не list
3. add_node и delete_node лучше реализовать с помощью операторов + - | ^ & ( вообщем операторы практически те же что и для set'а)

1. Как сделать функцию, которая для данного узла возвращает путь от него до корня
Python
1
2
3
4
5
def way_to_first_node(self):
  parent = self.parent
  while parent <> None: 
    yield parent
    parent = parent.parent
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.10.2014, 16:47
Помогаю со студенческими работами здесь

Дерево, компьютерные классы
Как сделать чтобы выводились только аудитории и факультеты у которых одинаковые аудитории? Задача: В некотором институте ...

Бинарное дерево поиска реализованное через классы
Здравствуйте. Нужно создать класс бинарное древо поиска. Пользователь вводит первое число N - количество звеньев в дереве. Потом N...

Классы, бинарное дерево, конструкторы. Исправить код
Здравствуйте! Не знаю, как исправить последнюю возникшую ошибку и заставить программу работать. А уже скоро сдавать и преподавателя...

Бинарное дерево поиска реализованное через классы
Здравствуйте. Нужно создать класс- бинарное древо поиска. Пользователь вводит первое число N - количество звеньев в дереве. Потом N...

Создать базовый класс «Садовое дерево» и производные классы «Яблоня», «Вишня», «Груша» и др
7. Создать базовый класс «Садовое дерево» и производные классы «Яблоня», «Вишня», «Груша» и др. С помощью конструктора автоматически...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru