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

Прошу разобраться с задачей на рекурсию. Как это сделать?

22.02.2023, 12:23. Показов 579. Ответов 5

Студворк — интернет-сервис помощи студентам
Плоды на дереве росли в соответствии с хитрым алгоритмом:
Первый плод вырастал на самой вершине дерева. Второй плод,
весивший 5 единиц вырастал слева, потому что был легче.

Название: d7691121f219de643d6e3138316463f5dcb8bfc4a[1].png
Просмотров: 64

Размер: 8.5 Кб

Третий плод был легче 10, но тяжелее 5, поэтому сначала он шел по
левой ветке, а потом вырастал справа от 5



Ну и дальше по аналогии, если плод легче, то он спускается по
левой ветке, если тяжелее – то по правой.



Оказалось, что во всем этом есть очень глубокий смысл. Если
обходить это дерево вот так:



И записывать вершины в том порядке, в котором они встретились,
мы получим отсортированную последовательность. Это верно для
любого дерева, построенного по вышеуказанному правилу.
Ваша задача описать класс такого дерева и создать на его основе
алгоритм сортировки.
Входные данные:
Входные данные представлены в формате:
<Количество плодов>
<Вес плода>
for I in range(<Количество плодов> - 1):
<Вес плода>

<Количество плодов> и <Вес плода> -- натуральные числа. Сначала
вне цикла читаем вес плода, чтобы инициализировать дерево.
Затем добавляем плоды к дереву при помощи add_el

Выходные данные:

Python
1
2
3
4
5
6
7
8
n = int(input())
T = Tree(int(input()))
for i in range(n - 1):
    k = int(input())
    T.add_el(k)
lst = []
T.my_sort(lst)
print(lst)
При запуске вышеприведенного кода выходные данные должны
быть следующими:
<Отсортированный список>

Примеры ввода/вывода:
Ввод:
10
3
4
1
3
5
1
3
5
2
1
Вывод:
[1, 1, 1, 2, 3, 3, 3, 4, 5, 5]
Ввод:
1
3
Вывод:
[3]
Ввод:
5
3
577676
458548458
548548458
437347347347347374
Вывод:
[3, 577676, 458548458, 548548458, 437347347347347374]
Примечание:
Сигнатура класса выглядит так:

Python
1
2
3
4
5
6
7
8
9
class Tree:
     def __init__(self, f):
          self.x = f
          self.right = None
          self.left = None
     def add_el(self, el):
          pass
    def my_sort(self, lst):
          pass
Метод my_sort надо выполнять с помощью рекурсии!
Если два элемента равны, то неважно, в какую сторону их
отправлять.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.02.2023, 12:23
Ответы с готовыми решениями:

Прошу помочь разобраться с задачей
Вопросы в теле программы #include &lt;iostream&gt; using namespace std; class Number// абстрактный класс производный для других...

Прошу помочь разобраться с готовой задачей
Привет всем! Прошу разобраться с такой задачей. Наверное многие из вас изучали курс ТОЭ (или хотя бы раздел физики под названием...

Прошу разобраться задачей плз (qBasic)
Дано натуральное число п (возраст).Обеспечить вывод этого числа с соответствующим словом: «год», «года», «лет».

5
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
22.02.2023, 19:44
Двоичное дерево поиска

Сортировка с помощью двоичного дерева
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38179 / 21114 / 4307
Регистрация: 12.02.2012
Сообщений: 34,721
Записей в блоге: 14
22.02.2023, 20:08
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
49
50
51
52
53
54
55
56
class Node:
    def __init__(self,n):
        self.value=n
        self.left=None
        self.right=None
        
    @staticmethod
    def arr2tree(arr):
        root=Node(arr[0]) # корень дерева
        for a in arr[1:]:
            Node.int2tree(root,a) # добавляем очередной элемент
        return root    
    
    @staticmethod
    def tree2arr(tree):
        if tree is None:
            return []
        else:
            return Node.tree2arr(tree.left)+[tree.value]+Node.tree2arr(tree.right)
    
    @staticmethod
    def treeSort(arr):
        tmp=Node.arr2tree(arr)
        return Node.tree2arr(tmp)
    
    @staticmethod
    def printtree(tree): # печать дерева
        if tree is None:
            return
        Node.printtree(tree.left)
        print(tree.value,end=' ')
        Node.printtree(tree.right)
 
    @staticmethod
    def int2tree(tree,n): # добавляем узел n в дерево tree
        if tree.value > n:
            # добавляем в левую часть
            if tree.left==None: # стоим на листе
                c=Node(n)
                tree.left=c # связываем новый узел с предком
            else:
                Node.int2tree(tree.left,n) # если это не лист - сдвигаемся влево
        else:
            # добавляем в правую часть
            if tree.right==None: # стоим на листе
                c=Node(n)
                tree.right=c # связываем новый узел с предком
            else:
                Node.int2tree(tree.right,n) # если это не лист - сдвигаемся влево
 
def start():
    arr=[5,7,-2,12,0,-8]
    sarr=Node.treeSort(arr)
    print(sarr)
    
start()
1
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
22.02.2023, 20:20
Catstail,

Не по теме:

у вас есть все реализации основных структур (деревьев, куч, стека, очередей и т.п.)

0
22.02.2023, 20:24

Не по теме:

Red white socks, двоичное дерево поиска, куча - да, есть. Пользуюсь постоянно. Стек и очередь при необходимости делаю из "подручных материалов". Другие - в процесс освоения. Присматриваюсь к хэш-таблицам, авл-деревьям.

0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
22.02.2023, 20:35
Catstail,
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.02.2023, 20:35
Помогаю со студенческими работами здесь

Прошу об услуге с 15 задачей,пожалуйста по C++. Уже долго не могу с ней разобраться)

Как разобраться с задачей. И как понять решение задачи, объясните пожалуйста.Можно ли как-нибудь по-проще её сделать?
Определить, чередуются ли положительные и отрицательные элементы в целочисленном массиве из 20 элементов. Если элементы чередуются, то...

Как это сделать через рекурсию?
using System; class Program { public int a = new int; public int n; public int k; public int rec(int i, int...

Как это задание сделать через рекурсию?
У меня есть задание посчитать биномальный коэфициент простым способом и через рекурсию. Простым способом я сделал, нужно теперь это...

Задали работу, не могу разобраться. Используется делфи 10, не могу разобраться, как это сделать
В одномерном массиве, состоящем из n вещественных элементов, вычислить: минимальный элемент массива и сумму элементов массива,...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Как дизайн сайта влияет на конверсию: 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-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru