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

Кодирование RLE на питон

12.11.2021, 15:28. Показов 2879. Ответов 1

Студворк — интернет-сервис помощи студентам
Что не так? Почему не выводит строчку с кодированием?

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
def rle_encode(data): #кодирование
    encoding = '' 
    prev_char = '' 
    count = 1 
 
    if not data: 
        return '' 
    for char in data: 
        if char != prev_char:
            if prev_char: 
                encoding += str(count) + prev_char 
                count = 1 
                prev_char = char 
            else:  
                count += 1
        else: 
            encoding += str(count) + prev_char 
            return encoding
encoded_val = rle_encode('43AADDDFFF')
print(encoded_val)
 
def rle_decode(data): #декодирование
    decode = '' 
    count = '' 
    for char in data:
       if char.isdigit():
          count += char 
       else:  
            decode += char * int(count) 
            count = '' 
    return decode
decoded_val = rle_decode('6A1F2D7C1A17E') 
print(decoded_val)
Миниатюры
Кодирование RLE на питон  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.11.2021, 15:28
Ответы с готовыми решениями:

Кодирование строки цифр в RLE
RLE означает “run-length encoding” — это способ сокращённой записи последовательности чего угодно (в случае этой задачи — цифр), при...

Питон кодирование массива
Выручайте пожалуйста, не могу справиться! С помощью numpy написать функцию для кодирование массива (Run-length encoding). Все подряд...

кодирование RLE
я составила для себя алгоритм допустим в файле |65|65|66| считали 65 считали следущее т.е. опять 65 считали следущее т.е....

1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38165 / 21100 / 4307
Регистрация: 12.02.2012
Сообщений: 34,688
Записей в блоге: 14
12.11.2021, 15:43
А так:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
def rle_encode(data): #кодирование
    encoding = '' 
    prev_char = '' 
    count = 1 
 
    if not data: 
        return '' 
    for char in data: 
        if char != prev_char:
            if prev_char: 
                encoding += str(count) + prev_char 
                count = 1 
                prev_char = char 
            else:  
                count += 1
        else: 
            encoding += str(count) + prev_char 
    return encoding
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.11.2021, 15:43
Помогаю со студенческими работами здесь

RLE кодирование
Есть бинарный файл неопределенной длины,необходимо сжать его используя RLE кодирование.Алгоритм записывает в входной поток вместо...

Реализовать RLE кодирование и декодирование
не могу сообразить каким образом реализовать RLE кодирование на С. Может тут мне помогут...

Кодирование длин серий (RLE)
Я уже полдня пытаюсь ошибку найти, всё 100 раз перепроверил и не могу всё равно найти в чем ошибка. У меня на входе файл 92,8 КБ, а на...

Кодирование длин серий RLE
Есть код алгоритма кодирования длин серий RLE. Но есть траблы с декодированием:( Вот код #include <iostream> #include...

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru