0 / 0 / 0
Регистрация: 11.08.2023
Сообщений: 3

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

13.08.2023, 02:36. Показов 1791. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru