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

Родословная: предки и потомки

13.08.2023, 02:36. Показов 1779. Ответов 5

Студворк — интернет-сервис помощи студентам
Условие:

Даны два элемента в дереве. Определите, является ли один из них потомком другого.

Программа получает на вход число элементов N в генеалогическом древе. Далее следует N - 1 строк, задающие родителя для каждого элемента древа, кроме родоначальника. Каждая строка имеет вид имя_потомка имя_родителя. Далее до конца файла идут строки, содержащие имена двух элементов дерева. Для каждого такого запроса выведите одно из трех чисел: 1, если первый элемент является предком второго, 2, если второй является предком первого или 0, если ни один из них не является предком другого.

Написал код - падает на 12 тесте (Ошибка выполнения). Подскажите, в чем может быть ошибка.

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
def go_up(s, t, T, IS):
    if T.get(s, None) is None:
        return
    else:
        IS[t + " " + T[s]] = 2
        IS[T[s] + " " + t] = 1
        go_up(T[s], t, T, IS)
        
        
n = int(input())
T = {}
IS = {}
used = set()
for i in range(n - 1):
    s = input()
    T[s.split()[0]] = s.split()[1]
try:
    s = input()
except EOFError:
    quit()
while True:
    if s.split()[1] not in used:
        used.add(s.split()[1])
        go_up(s.split()[1], s.split()[1], T, IS)
    if s.split()[0] not in used:
        used.add(s.split()[0])
        go_up(s.split()[0], s.split()[0], T, IS)
    print(IS.get(s, 0))
    try:
        s = input()
    except EOFError:
        quit()
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.08.2023, 02:36
Ответы с готовыми решениями:

Родословная: предки и потомки
В генеалогическом древе у каждого человека, кроме родоначальника, есть ровно один родитель. Каждом элементу дерева сопоставляется...

Родословная: предки и потомки
Условие Даны два элемента в дереве. Определите, является ли один из них потомком другого. Во входных данных записано дерево в том же...

Родословная: предки и потомки
В генеалогическом древе у каждого человека, кроме родоначальника, есть ровно один родитель. Каждом элементу дерева сопоставляется...

5
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
13.08.2023, 09:55
Лучший ответ Сообщение было отмечено snej0ke как решение

Решение

Цитата Сообщение от snej0ke Посмотреть сообщение
Написал код - падает на 12 тесте (Ошибка выполнения). Подскажите, в чем может быть ошибка.
Ну, может быть там памяти для всех строк не хватило.
А если так:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
def is_parent(a, b):
    try:
        return a in d_parent_of[b] or is_parent(a, d_parent_of[b])
    except:
        return False
 
n = int(input('n = '))
d_parent_of = {}
for i in range(n-1):
    child, parent = input('s1->').split()
    d_parent_of[child] = parent
try:
    while True:
        a, b = input('s2->').split()
        if is_parent(a,b):
            print('1')
        elif is_parent(b,a):
            print('2')
        else:
            print('0')
except:
    pass
2
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
13.08.2023, 10:51
snej0ke, посмотрите на работу своего кода при N=1
0
0 / 0 / 0
Регистрация: 11.08.2023
Сообщений: 3
13.08.2023, 12:49  [ТС]
Ваше решение работает, спасибо

Все таки, как можно исправить проблемы с памятью? Спрашиваю для интереса, пока плохо разбираюсь в этом
0
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
13.08.2023, 12:59
Цитата Сообщение от snej0ke Посмотреть сообщение
как можно исправить проблемы с памятью?
Ну, входные данные могут быть любые. Вам могут заправить такое дерево, что памяти не хватит, так как занимаемая память пропорциональна квадрату количества элементов дерева, если записывать данные для каждого с каждым, как у вас.
0
Вирусоборец
 Аватар для thyrex
14449 / 7488 / 1582
Регистрация: 06.09.2009
Сообщений: 27,132
13.08.2023, 14:02
Похожая задача, которая отличается лишь одним данным на входе, есть на Степике. Там же есть примеры данных.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.08.2023, 14:02
Помогаю со студенческими работами здесь

создать класс(предки, потомки)
Создать иерархию классов транспортные средства – автомобиль – грузовик. Определить методы создания транспортного средства, изменения...

ООП+матрицы(предки потомки)свойства и т.п. нужна помошь
Всем привет. Вот собственно задача: Описать тип-объект MATRIX (матрица произвольной размерности M*N) и его методы: ввод матрицы; вывод...

Предки в графах
Задача на определение, является ли вершина предком другой Условие: Определить для двух вершин дерева , является ли одна из них предком...

Родословная
В генеалогическом древе у каждого человека, кроме родоначальника, есть ровно один родитель. Каждому элементу дерева ставится в...

Родословная
Построение генеалогического древа на основе описания связей между членами семьи Входные данные: Описание связей между членами семьи ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru