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

Рекурсивное заполнение и чтение из словаря

31.08.2020, 12:45. Показов 3074. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Мне необходимо заполнить словарь, так, чтобы получилось дерево. Данные представляются буквами английского алфавита и подобранным для них кодом.
Пример:
a: 0
b: 10
c: 110
d: 111

Готовый словарь, соответственно, будет выглядеть как-то так:
Python
1
d = {1: {1: {1: 'd', 0: 'c'}, 0: 'b'}, 0: 'a'}
Я пытаюсь написать рекурсивную функцию, которая будет заполнять словарь. Ничего не выходит, т.к. я не понимаю, какие аргументы передавать, чтобы следующие итерации функции переходили все глубже в словарь. Пытался разными способами. Заканчивалось тем, что я добирался туда, куда нужно, но в функции хранился непосредственно последний уровень словаря, а не данные о том, как туда попасть, чтобы впоследствии добавить в него данные.
Ощущение, будто упускаю что-то совсем банальное и глупое.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.08.2020, 12:45
Ответы с готовыми решениями:

Рекурсивное раскрытие словаря
Здравствуйте! Подскажите как рекурсивно пройтись по примерно такой структуре: {"OP1" : }, {"OP2" :...

Рекурсивное создание словаря с типами и размерами файлов
Здравствуйте. Рекурсивно прохожу по директории. В словарь qmap записываю расширение файла, и его размер. если встречаю папку, спускаюсь...

Рекурсивное заполнение БД
Добрый день! Переношу базу данных с битрикса на OpenCart. В основном скриптами, в некоторых местах - вручную. Имеется таблица...

4
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
31.08.2020, 13:30
Узнаю, жадные алгоритмы, кодирование Хаффмана

Цитата Сообщение от nbray Посмотреть сообщение
которая будет заполнять словарь.
Цитата Сообщение от nbray Посмотреть сообщение
переходили все глубже в словарь.
Так всё-таки, с чем проблема - с заполнением или с чтением?
0
0 / 0 / 0
Регистрация: 31.08.2020
Сообщений: 2
31.08.2020, 13:34  [ТС]
В точку попали, это Хаффман.

Проблемы с заполнением. Мб потом будут и с чтением, но до этого я еще не дошел.
Сейчас прочитал, что коды сначала лучше отсортировать в лексикографическом порядке, тогда будет полегче. Но я все равно не могу понять построить это дерево
0
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
31.08.2020, 14:07
Особо не тестировал.
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
symbols = [
    ('a', 0),
    ('b', 10),
    ('c', 110),
    ('d', 111)
]
 
 
def most_significant_digit(x: int) -> int:
    return int(str(x)[0])
 
 
def tail(x: int) -> int:
    return int(str(x)[1:])
 
 
def append(node: dict, symbol, code):
    if code == 0 or code == 1:
        assert code not in node
        node[code] = symbol
        return
    msd = most_significant_digit(code)
    subtree = node.setdefault(msd, {})
    code_tail = tail(code)
    append(subtree, symbol, code_tail)
 
 
tree = {}
for symbol, code in symbols:
    append(tree, symbol, code)
 
print(tree)
1
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
31.08.2020, 14:15
Чесгря, плохо уже помню, как там заполняется, но вроде просто.
Проходим по 1й цифре. Там, где "лист", нолик, ставим букву. Где не-лист, т. е. 1, ставим пустой словарь.
И на следующую цифру. Повторить.
Коды, которые кончились, не рассматриваем.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.08.2020, 14:15
Помогаю со студенческими работами здесь

Рекурсивное заполнение массива 0 и 1
Как рекурсивно заполнить двумерный массив из 2 в степени N разрядов? Чтобы это выглядело так: при N=3 0 0 0 0 0 1 0 1 0 0 1 1 1...

Рекурсивное заполнение TreeView из БД
Добрый день, очень прошу помощи! Помогите, очень срочно, мучаюсь два дня! На Делфи пишу впервые, просмотрела много тем, так и не нашла...

Рекурсивное заполнение дерева
Извиняюсь, вопрос, наверно, сильно тривиальный, но голова совсем что-то не варит, не подскажите как организовать рекурсивное (или не...

Рекурсивное заполнение treeView
Добрый день! Помогите пожалуйста написать рекурсивный алгоритм, а то рекурсию некогда до конца не понимал :wall: Вообщем, у меня...

Рекурсивное заполнение treeView - не могу разобраться
Всем доброго времени суток, имеется treeView, структура нодов которого сохранена в таблице БД. public class treestruct { ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
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 https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью 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. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru