Задача: Написать код минимально возможной длины, выводящий полученную на вход, строку из цифр большим, символьным шрифтом. Шрифт должен быть в точности такой, как указан тут, в вопросе. Пример: На вход получена строка "0123456789", на стандартный вывод программа должна вывести: ### # ##### ##### # ####### ##### ####### ##### ##### # # ## # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # ##### ##### # # ###### ###### # ##### ###### # # # # # ####### # # # # # # # # # # # # # # # # # # # # # # # ### ##### ####### ##### # ##### ##### # ##### ##### Правила и ограничения: Программа может, но не обязана быть оформленной в виде функции. Если она функция - синтаксис объявления этой функции (int main() {} для C) не учитывается в размере, важен размер самого рабочего кода. Входная строка может поступать в программу любым, удобным вам, способом: в виде переменной, указанной в тестовом примере непосредственно перед кодом, в виде параметра функции или со стандартного ввода. Входная строка может содержать только цифры Результат должен быть выведен на стандартный вывод в текстовом виде. Если стандартный вывод направлен на терминал, экран считать достаточной ширины для вывода всего контрольного примера c запасом. Переход на новую строку обозначайте (явно или не явно) любым символом/комбинацией символов, использующейся для перевода строки на вашей платформе (Например, или ). Шрифт результата должен в точности соответствовать указанному выше. Между цифрами на выводе должен быть минимум один пробел (цифры не должны сливаться). Шрифт считается моноширинным, т.е. вокруг единицы может быть больше пустого пространства т.к. ее изображение ýже остальных цифр. В программе запрещено использовать любые встроенные в язык и библиотеки к нему функции сжатия и кодирования данных (Такие как: zip/unzip, base64) Программа должна содержать шрифт (или код его формирующий) непосредственно в своем теле. Получать шрифт из внешних источников (ввод, диск, сеть, память видеоадаптера, bios) запрещено. Размер программы учитывается в байтах. Побеждает программа имеющая минимальный размер
Конкурс окончен Первое место занимает @RusArt с ответом на 05AB1E, длиной всего 91 "байт". Втрое место занимает @Anton Petrusevich с ответом на perl, длиной 150 байт. И третье место достается @retorta с ответом на python, длиной 161 байт. В ответах рассмотрены самые разные способы сжатия шрифта. При подготовке к конкурсу я рассматривал большинство из них. Самым простым для реализации и в то же время достаточно эффективным оказалось сжатие до 70 байт в 7 битной, горизонтальной, кодировке (оригинальное моя кодировка представлена в ответе на postgresql. Даже удалось попасть в диапазон допустимых символов, поменяв 6-7 биты и вычтя 2. Правда не все участники заморачивались и тратили драгоценные байты на кодирование в диапазон печатных символов с 0x20 до 0x7E. Применяли кодирование как есть, часто с 8 битом или залезая вообще в диапазон управляющих. В принципе такое кодирование имеет право на жизнь, программы на той платформе, где писались работают. Хотя мне и не очень нравится когда программу нельзя напечатать на принтере, ввести по новой с листа и что бы при этом она продолжила работать (Вы не сможете опубликовать свой код в книге ) ). Победителем была использована совершенно другая кодировка шрифта. Словарь из 16 возможных 7и символьных элементов шрифта (в битовом кодировании) и кодовая таблица с номерами частей для каждого символа, которая благодаря нестандартной кодовой странице языка 05AB1E заняла 35 "байт" (технически в этом языке используются 256 графем, которые принято считать "байтами" потому что их именно 256 и если бы реально существовала такая кодовая таблица, то их все действительно можно было бы закодировать одним байтом). К сожалению подобное кодирование в других языках невозможно в принципе, в связи с тем, что из 256 значений байта в кодировке ASCII 31 используется для управляющих кодов, а 128 старших значений плохо переносятся между платформами. Подобный подход со словарем в принципе был использован еще в нескольких ответах, но там не применялось бинарное кодирование в результате чего шрифт занимает гораздо больше места. В процессе подготовки конкурса я рассматривал даже несколько вариантов кодирования со словарем. Например, две комбинации ##### и # #, встречающиеся очень часто, предполагалось кодировать двумя битами со значениями 10 и 11, а остальные варианты 5и битным значением, первый бит которого 0, что бы отличить от первых двух и остальные 4 бита номер варианта. На практике же это давало совсем небольшой выигрыш в кодировании шрифта и при этом код декодирования оказывался слишком сложным и в код-гольфе неприменимым и опять же в обычном ascii коде уложить это очень сложно. В ответах можно найти и совершенно иные способы кодирования, например, кодирование повторов # и пробелов просто количествами подряд, представленном в ответе @Qwertiy К сожалению никто из участников не пробовал использовать вертикальное кодирование, т.е. где элементом выступает 7 бит кодируемого символа берущихся из него по вертикали. А при таком способе кодирования получается очень много повторов. Присмотритесь к цифрам 5689 у них отличаются только 1 и последняя вертикаль, остальные одинаковы. При кодировании повторов в такой строке удается достичь практически такого же сжатия как и в случае с словарем и битовым кодированием. Но на практике гольфа опять же слабо применимое из за роста объема декодирующего кода.
Альтернативный рейтинг К сожалению не удалось сформулировать правила так, что бы они действительно отражали то, чего я хотел от конкурса. Во многих ответах используются символы не работающие в другой кодировке символов или функции близкие по смыслу к base64, т.е. представляющие закодированную строку как одно большое число, в результате чего в коде отсутствует собственноручное ее декодирование. В данном альтернативном рейтинге я отражаю результаты, как бы они выглядели, если бы правила были точно сформулированы. Anton Petrusevich, ответ на perl, длиной 150 байт Андрей, ответ на C#, длиной 176 байт Visman, ответ на PHP, длиной 235 байт
Пожалуйста, указывайте в ответе количество байт, чтобы проще было выявить победителя.
Ответ Python3, 161 байт def f(s): for i in'0123456':print(*(format(b'>>@>>>"AAB@ABAAA(B@@AAA>>B~~>?A@AA"@AAAAA>>>>>>'[int(i+j)],'7b').translate({48:' ',49:'#'})for j in s)) SO режет некоторые символы, так что код скопированный отсюда не будет работать, но если скопировать отсюда, то всё работает. Проверка