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

Кодирование методами Шеннона-Фано и Хафманна

13.04.2021, 20:48. Показов 23267. Ответов 2

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста, не знаю уже, как с эти кодом бороться...
Задание звучит следующим образом:
Используя заданный текст построить оптимальный неравномерный код, применяя:
- Метод Шеннона-Фано;

У меня начинаются проблемы со следующих строк:
for i in '!—,.-?...()—:;«»\nъь':
slovar.pop(i)

KeyError: '.'

И дальше тоже программа не особо работать хочет
Вложения
Тип файла: txt Кодирование.txt (2.6 Кб, 278 просмотров)
Тип файла: txt 25var.txt (10.2 Кб, 222 просмотров)
1
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.04.2021, 20:48
Ответы с готовыми решениями:

Кодирование+декодирование методами Шеннона-Фано и Хемминга
Требуется сабж на Delphi. Дается файл, который следует закодировать, потом полученный закодированный файл декодируется. Требуются оба...

Эффективное кодирование информации методами Шеннона-Фано и Хаффмана
Доброго времени суток! Может кто помочь в написании?В делфи почти не шарю( Проблема удалить из массива повторяющиеся элементы и записать...

Кодирование Фано-Шеннона
Добрый день. Есть недочет в коде, цель закодировать и декодировать строку алгоритмом Фано-Шеннона. Проблема в том, что если кодировать...

2
130 / 41 / 19
Регистрация: 31.03.2020
Сообщений: 63
13.04.2021, 22:21
Лучший ответ Сообщение было отмечено KRISS2001BOOM как решение

Решение

Вроде что-то получилось:
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
Code = []
file = open("text.txt", encoding='utf8')
text = file.read().lower()
file.close()
d = {}
for i in text:
    if i not in '!—,.-?...()—:;«»\nъь':
        d[i] = d.get(i, 0) + 1
sum_sim = sum(d.values())
for i in d:
    d[i] = round(d[i] / sum_sim, 3)
d = sorted(d.items(), key=lambda x: x[1], reverse=True)
arr = []
for i in d:
    arr.append(list(i) + [''])
 
 
def func(arr):
    half = sum(map(lambda x: x[1], arr))
    sum1 = 0
    for i, j in enumerate(arr):
        sum1 += j[1]
        if sum1 * 2 >= half:
            index = i + (abs(2 * sum1 - half) < abs(2 * (sum1 - j[1]) - half))
            break
 
    arr0, arr1 = [], []
    for i in arr[:index]:
        i[2] += '0'
        arr0.append(i)
    for i in arr[index:]:
        i[2] += '1'
        arr1.append(i)
 
    if len(arr1) == 1:
        Code.append(arr1)
    else:
        func(arr1)
    if len(arr0) == 1:
        Code.append(arr0)
    else:
        func(arr0)
 
func(arr)
print('\nКод Шеннона-Фано: \n')
for i in Code:
    print(i)
2
0 / 0 / 0
Регистрация: 12.04.2022
Сообщений: 2
13.06.2022, 20:58
Здравствуйте! А можете объяснить подробнее, пожалуйста, 24 строчку {index = i + (abs(2 * sum1 - half) < abs(2 * (sum1 - j[1]) - half))}?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.06.2022, 20:58
Помогаю со студенческими работами здесь

Кодирование Шеннона-Фано
Окей мы посчитали вероятности символов и прочие штуки.. Далее нужно создать таблицу уник. символов.. Сделали.. отсортировали... В...

Кодирование Шеннона-Фано
Как реализовать метод Шеннона-Фано без использования дерева?

Кодирование методом Шеннона-Фано
Добрый день! Нужно доработать программу: #include &lt;iostream&gt; #include &lt;string&gt; using namespace std; int main() { string...

Алгоритм кодирование Шеннона-Фано
Все здравствуйте) Такая тема, реализовал алгоритм Шеннона-Фано по наработкам из интернета, но он ни в какую не принимает в расчёт...

Кодирование методом Шеннона-Фано и Хаффмана
Добрый день уважаемые форумчане, не могу выполнить задание по дискретной математике, нужно написать программу которая будет кодировать...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru