Wyjście „Lorem ipsum” z minimalną liczbą znaków


16

Pamiętam ludzi, którzy mówili, że rozmiar kodu powinien być mierzony w bajtach, a nie w znakach, ponieważ możliwe jest przechowywanie informacji z dziwnymi znakami Unicode, które nie mają żadnego znaczenia wizualnego.

Jak źle może być?

W tym wyzwaniu powinieneś wydrukować następujący tekst Lorem Ipsum, pobrany z Wikipedii :

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.

Podaj liczbę znaków (nie bajtów) w kodzie. Wygrywa kod z minimalną liczbą znaków.

Twój kod powinien zawierać tylko prawidłowe znaki Unicode, jak opisano tutaj , to znaczy:

  • Punkty kodowe do U + 10FFFF
  • Bez surogatów (zakres D800 – DBFF jest zabroniony)
  • Brak znaków FFFE i FFFF
  • Brak znaków zerowych (kod 0)

Jeśli nie można wyświetlić Twojego kodu, podaj wersję ze zmienionymi postaciami obrażającymi i zrzut heksowy.

Niektóre uwagi:

  • Dane wyjściowe muszą mieć jedną długą linię (445 znaków). Jeśli twój system nie może tego zrobić (np. Drukujesz na papierze), wyświetl najbliższe przybliżenie. Końcowe łamanie linii nie ma znaczenia.
  • Wbudowane funkcje generujące tekst Lorem Ipsum są niedozwolone
  • W razie potrzeby podaj prawidłowe kodowanie tekstu dla swojego kodu

2
Niestety =lorem()w MS Word nie wyświetla właściwej wersji
BlackCap

4
3 odpowiedzi do tej pory określające bajty. Sądzę, że niektórzy ludzie mogli nie przeczytać wyzwania
Robert Fraser

@RobertFraser: W moim przypadku nie ma znaczenia, ponieważ 1 bajt = 1 znak, więc równie dobrze mogę podać bajty, jak to jest standardem. Gdybym zarabiał, używając znaków, to bym tak określił :) Z całą pewnością to samo dotyczy innych odpowiedzi.
Emigna

1
Czy można złożyć wniosek HTTP?
Master_ex

2
To wydaje się duplikatem tego wyzwania, ponieważ w tekście nie ma żadnych wzorów?
FryAmTheEggman

Odpowiedzi:


6

Dyalog APL , 123 znaki

Wszystkie oprócz ostatniego okresu są pakowane w 111 znaków 32-bitowych (UTF-32).

'.',⍨80DR'𦽌򒁭󗕳󆽤𲁲𒁴󇑥󦽣񆍥𧕴򖑡𷍩􆝮񆥬񗌠󶐠񖥥񆽭󖕴􇉯򖍮񖑩񒁴𖰠񗉯􇑥󶱯󒁥𖹧򖱡󦅵􇑕󖥮􆑡򖹩񗘠󖅩񗄠󢁳𧑳񒁤𷉥񆅴􆹯𖱬􆽣󶉡􇍩򗍩􇑵𖥬􇁩񒁸󶌠񆽭󶌠𖕳󧑡򗕄񖄠򒁥񗉵󆽤򒁲񗈠򆕲񖑮􇑩񢁮􇕬񗑡󆕶񒁴􆕳󆱩񂁭𦽬񖔠񷕦􇑡󆱵𗀠񆅩􂹲񖍸񖕴򗌠󲁴񖅣􇑡򗁵𗑡󶸠𧀠񖑩􂱴񆹵􆹩􆱵񗄠񦼠򖍩񖐠񗉥󒁴򖱬󦄠򒁭𶔠𖰠񗉯'

'.',⍨ okres dołączony do

80⎕DR8-bitowy ( 8) znak ( 0) D ata R reprezentacja

'... '111 znaków Unicode U + 26F4C 9206D D7573 C6F64 32072 12074 C7465 E6F63 46365 27574 96461 37369 10676E 4696C 57320 F6420 56965 46F6D D6574 10726F 9636E 56469 52074 16C20 5726F 107465 F6E696 10620 46174 106E6F 16C6C 106F63 F6261 107369 97369 107475 1696C 107069 52078 F6320 46F6D F6320 16573 E7461 97544 56120 92065 57275 C6F64 92072 57220 86572 5646E 107469 6206E 10756C 57461 C6576 52074 106573 C6C69 4206D 26F6C 56520 77566 107461 C6C75 17020 46169 102E72 56378 56574 97320 F2074 56163 107461 97075 17461 F6E20 27020 56469 102C74 46E75 106E69 106C75 57120 66F20 96369 56420 57265 D2074 96C6C E6120 9206D 36520 16C20 5726F, które wszystkie mieszczą się w zakresie 12074–10756C, a zatem mieszczą się w dozwolonym zakresie OP 10000–10FFFF.


14

JavaScript (ES7), 326 283 273 249 243 242 znaków

_=>"򾍮󂙙󱤭󕜛񟉝񚫎󸦘󏇌󻮾󪕍򦙜񴫰𭙝𧇍񛜃򧮖󓔽򅬸󪙗񴦲񿫽񟮩򺥸󫡽񛜕󖷉󂨗񢕕򦯊񗮣󌫉񣔶򥹖񟷗򢫂󧩜񝼜󾿍񙇛񴮪󼬗񟪵񥦘񝕋󖹜񝹜򢟝񚪲󧩙񙁪񛌖󆆸񛌗󳭞񧔍􄮉񧮮񜭾󫤭󕜛񜫩󫬻򄗗񻭲󺙗񟼕􆞪󻤿򅙝𯎎񛉕򹤭󕜛򀿉򏨒񧔷􅚪񞕛򢮾󪂌򆞮􆴼򥾩󓆊򃅝񛏙򣕝񧔷󕴹󮉍򅾢󷫽񜫩񷪹񢝞򢜏򌦒񢖮󳭾󏔶󕚲󺕗򥤲񸾝񝕋󖿇"[r='replace'](/./gu,c=>(c.codePointAt()-4**8).toString(32))[r](/\d/g,d=>"  , exum. ".substr(d,2))[r](/^.|\. ./g,x=>x.toUpperCase())

Jak to działa

Pierwszym krokiem w mojej technice kompresji jest konwersja całego łańcucha na małe litery (nie jest to obowiązkowe, ale wygląda lepiej) i zamiana każdej pary znaków w , exum. (jak również sama spacja) na jej indeks w ciągu plus 2. To sprawia, że ​​tekst jest poprawnym numerem 32:

lorem9ips69dolor9sit9amet2consectetur9adipiscing3lit2sed9do3iusmod9tempor9incididunt9ut9labore3t9dolore9magna9aliqua8ut3nim9ad9minim9veniam2quis9nostrud94ercitation9ullamco9laboris9nisi9ut9aliquip943a9commodo9consequat8duis9aute9irure9dolor9in9reprehenderit9in9voluptate9velit3sse9cill69dolore3u9fugiat9nulla9pariatur84cepteur9sint9occaecat9cupidatat9non9proident2sunt9in9culpa9qui9officia9deserunt9mollit9anim9id3st9laboru7

Następnym krokiem jest konwersja każdego przebiegu 4-znakowego na dziesiętny, a następnie uzyskanie znaku w tym punkcie kodu. Można to zrobić za pomocą następującej funkcji:

f=s=>s.replace(/..../g,x=>(n=parseInt(x,32),String.fromCharCode(0xD800+(n>>10),0xDC00+(n&0x03FF))))

( Uwaga: Ponieważ wszystkie cyfry mają 2 lub więcej, minimalna możliwa wartość czterech cyfr to 2222₃₂. Jest to równe 95978₁₀ lub 176EA₁₆; dlatego punkty kodowe nigdy nie będą w ograniczonym zakresie).

A teraz mamy nasz skompresowany ciąg:

򾍮󂙙󱤭󕜛񟉝񚫎󸦘󏇌󻮾󪕍򦙜񴫰𭙝𧇍񛜃򧮖󓔽򅬸󪙗񴦲񿫽񟮩򺥸󫡽񛜕󖷉󂨗񢕕򦯊񗮣󌫉񣔶򥹖񟷗򢫂󧩜񝼜󾿍񙇛񴮪󼬗񟪵񥦘񝕋󖹜񝹜򢟝񚪲󧩙񙁪񛌖󆆸񛌗󳭞񧔍􄮉񧮮񜭾󫤭󕜛񜫩󫬻򄗗񻭲󺙗񟼕􆞪󻤿򅙝𯎎񛉕򹤭󕜛򀿉򏨒񧔷􅚪񞕛򢮾󪂌򆞮􆴼򥾩󓆊򃅝񛏙򣕝񧔷󕴹󮉍򅾢󷫽񜫩񷪹񢝞򢜏򌦒񢖮󳭾󏔶󕚲󺕗򥤲񸾝񝕋󖿇

To 445 znaków skompresowanych do 106 znaków. Dekompresja po prostu odwraca ten proces:

  1. Konwertuj każdy znak do punktu kodowego w bazie-32, minus 65536.
  2. Zastąpić każdą cyfrę nz " , exum. ".substr(n,2).
  3. Konwertuj każdą literę po kropce lub na początku łańcucha na wielkie litery.

Jedyną używaną funkcją ES7 jest **. Wymień 4**8się 65536uruchomić w przeglądarce, która nie obsługuje jeszcze ES7.


Jeśli używasz ES7, możesz użyć 4**8zamiast 65536.
mbomb007

@ mbomb007 Thanks. Być może przyda się to również w innych wyzwaniach
ETHproductions

8

bash + coreutils + gzip + recode, 191 znaków

echo -ne "ᾋࠀ㰟퍗\03㖐셱䌱ࡄ戋⪒宮⦀⃬〣ख़ʏ쬏湂삲מּ浊莎ᔍ얪䴬畐Ꮏ肭⽡តप㩴뇶ᮤ樶鞔岀梬昅⹭盖ꈥ먣Ვ빓ỢꞴꃑ괓꣪㷨삗䎺뛔䛓ﵸ摉篨䊷૤⦓헉픺ꉖ橬ꟲỒꗻ퉋則ใ⢍럴摧耼񸺷⒅୴䘺㦳櫇鐱窑駁愵䚞鎴鍉Ⅻक़毽➔脂ힸ⤹喝葁㎋頇㺞ⳃ┶왤惌⒜猜䌋吏젔掚ᛩ鯢⚕䜹鴛皽⨫ꇈ銹믍䄛逦軵융󌒣杻龇븁\0"|recode u8..utf16be|tr -d ٣ܣ|gunzip

Łańcuch jest gzipem tekstu interpretowanego jako UTF-16BE, plus kilka dodatkowych bajtów do sparowania z niesparowanymi połówkami zastępczymi. Tr usuwa dodatkowe połówki surogatu.

Ten plik skryptu (lub powłoka, w której wpisano to polecenie) powinien interpretować tekst jako UTF-8, dlatego konieczne jest ponowne kodowanie.


Witamy w PPCG! Miły pierwszy post! Liczymy jednak tutaj bajty. Przepraszam.
Rɪᴋᴇʀ

6
To pytanie stanowi wyraźny wyjątek od tego, stwierdzając „Proszę podać liczbę znaków (nie bajtów) w kodzie” i omawiając, które znaki Unicode są dozwolone.
user59468,

1
Jestem idiotą. Przepraszam za to. > _>
Rɪᴋᴇʀ

2
Nie ma problemu, założę się, że bajty - znaki to częsty błąd w innych pytaniach.
user59468,

8

JavaScript (ES6), 261 255 254 znaków

Zaoszczędzono 1 bajt dzięki produktom ETH

_=>'L'+"⫒㠰拳␰䨒堵̎⨦W䙨ⅶ嵷˘㥆姳䗨⠬巯堡Ŋɩ懪䨶尩个˒≎㥎䜩怷㰷䤆ŵ̊㹩⫒ᨠᩌ㳠抮f̅㩊ᠰ䀩㩎搰㩊ئ抠ˮ婱拗⠩啺巨㬆ɒ㸘∦㰲䤆姵㩀Ƕ̘㨆㬴⠳⠺…䈲䥒䤠⫱᬴w㬣ᠶ⬘嗠⫘䥀噯䗠⫀⫓䕭啩̎Ɏ㹹庘⬆⭀巯奠Ŷ㷨䌯䥀噯⠪ⰸ㦸̆㼱ï哳峮૘梠䵨慷堵幎≠⣨峨愠◳ᬆ䐷ɒ䫓⥎ܑ拠̑Ɏ㼨ó㬴⹠⇫î奩拊̑㹰巯䓠ȮŎ廪ᨀ噧ਸ".replace(/./g,c=>(s=" ,.DEUabcdefghilmnopqrstuvx")[(c=c.charCodeAt()-32)&31]+s[c>>5&31]+s[c>>10])

Awaria

Ładowność: 148 znaków Unicode
Kod: 107 bajtów

Jak to działa

Najpierw usuwamy wiodące 'L'z oryginalnej wiadomości, aby pozostać z 444 = 148 * 3 znaków.

Bez 'L'znaków wiodących zestaw znaków składa się z 27 następujących znaków:

" ,.DEUabcdefghilmnopqrstuvx"

Każda grupa 3 znaków jest kodowana jako:

n = 32 + a + b * 32 + c * 32^2

gdzie a, b i c są wskaźnikami znaków w powyższym zestawie znaków.

Prowadzi to do punktu kodu Unicode z zakresu od U + 0020 do U + 801F, kończącego się gdzieś w „Unifikowanych ideografach CJK”.

let f =
_=>'L'+"⫒㠰拳␰䨒堵̎⨦W䙨ⅶ嵷˘㥆姳䗨⠬巯堡Ŋɩ懪䨶尩个˒≎㥎䜩怷㰷䤆ŵ̊㹩⫒ᨠᩌ㳠抮f̅㩊ᠰ䀩㩎搰㩊ئ抠ˮ婱拗⠩啺巨㬆ɒ㸘∦㰲䤆姵㩀Ƕ̘㨆㬴⠳⠺…䈲䥒䤠⫱᬴w㬣ᠶ⬘嗠⫘䥀噯䗠⫀⫓䕭啩̎Ɏ㹹庘⬆⭀巯奠Ŷ㷨䌯䥀噯⠪ⰸ㦸̆㼱ï哳峮૘梠䵨慷堵幎≠⣨峨愠◳ᬆ䐷ɒ䫓⥎ܑ拠̑Ɏ㼨ó㬴⹠⇫î奩拊̑㹰巯䓠ȮŎ廪ᨀ噧ਸ".replace(/./g,c=>(s=" ,.DEUabcdefghilmnopqrstuvx")[(c=c.charCodeAt()-32)&31]+s[c>>5&31]+s[c>>10])


console.log(f())


5

05AB1E , 319 bajtów

Wykorzystuje kodowanie CP-1252.

•9y†QHÚSe²ŒÓdéÓ#ǧÖN›Íˆž4GÏóREØån‡·JîÁØ£ÎÁ¥evÑRZ¶—¥1RËÒÆzçå"UNé¨v¯ÊcŒÔÝjðtrœÛeã&“SÁxÌ4Þá1N$ù?T(çÛbŸœfó˜lUž}Þß-©ÃMšBÈÑPàê#jÇÐ+n¼BDFý>–¸äFT×›qÜY³ö9ªòËùˆA‡¾p=‘¤ÚÞ{I¶Œ±Ål#¨5´Aq˜Àž,s<*Ï;‡õã¾»ðŽL´ÅuØö+Xi+S>»/8Kã~WΔƒß”¤µðWluØa'cUÐeà¥ä…ž+œ6*0RU£›aÝQ_ñœoþÏð””Þã7ã¨sŒV`_É-´éÄèÆd¦úE5Í^Aá,‘‡™™¢äTHä0¥3±.}Søg•36B0„. :™J'yð:'z',:'.«

Interpretuj następujący ciąg jako liczbę podstawową 36 i koduj do podstawy 214

LOREMYIPSUMYDOLORYSITYAMETZYCONSECTETURYADIPISCINGYELITZYSEDYDOYEIUSMODYTEMPORYINCIDIDUNTYUTYLABOREYETYDOLOREYMAGNAYALIQUA0UTYENIMYADYMINIMYVENIAMZYQUISYNOSTRUDYEXERCITATIONYULLAMCOYLABORISYNISIYUTYALIQUIPYEXYEAYCOMMODOYCONSEQUAT0DUISYAUTEYIRUREYDOLORYINYREPREHENDERITYINYVOLUPTATEYVELITYESSEYCILLUMYDOLOREYEUYFUGIATYNULLAYPARIATUR0EXCEPTEURYSINTYOCCAECATYCUPIDATATYNONYPROIDENTZYSUNTYINYCULPAYQUIYOFFICIAYDESERUNTYMOLLITYANIMYIDYESTYLABORUM

Po tym my

36B                      # encode back into base 36
   0„. :                 # replace 0 with ". "
        ™J               # convert to titlecase and join
          'yð:           # replace "y" with <space>
              'z',:      # replace "z" with ","
                   '.«   # add a "." at the end

Z jakiegoś powodu kodowanie nie działało z cyfrą 0 na końcu, dlatego potrzebujemy specjalnego przypadku dla końcowego „.”.

Wypróbuj online!


Myślę, że można zastąpić Ya Zprzez 1a 2i zaoszczędzić kilka bajtów. A może może zmienić kolejność 0, 1 i 2, aby pozbyć się tajemniczego specjalnego przypadku?
anatolyg

@anatolyg: niestety nie. Wszelkie nieliterowe liczą się jako podział na słowa, które mogłyby zepsuć się z tytułem.
Emigna

5

PHP, 247 znaków

połączenie 2 poprzednich wersji

echo gzuncompress(base64_decode(mb_convert_encoding("敊眱歍䙸兺䕉剆癚䅪礯極南慷潧楏㡷䥷汚䅯⽌䐸灐扫䱁獶猫扅煄橨啎硡灎䱈噑䔷⭂牓㥨䘴㡊䭪瀰獦夷灇漲氵剣杇楳婧啵扥卹摴慩䩢潪䡊圫啨㝩氷卧ぢご煏潪㙍䍮儷焲ㅅ扔⽘桭卥㉇别桃琫啺䍵公欹塊ㅔ煩噭灳氯䥥ぱ堷ぱ⭫橨祇啂灶㙣浵䅈湋䐷硴卑潘㙉砰捭塖橩汪祲昰䥪佄㔸晔慯眸䨲歮欰䱗䕲䑗⭫㡯䅷塏畃猵⭪慅兔佌流晥塹穄䩔扇婇䑍䩊硺䡅䵌⭤㝉䙇佡䙵浢㑩慖剺湱潊ぢ摰㝋卩楹婏㕵猷灴ぁ慫楗倹捙ㄲ⽁䍧塋啊","UTF-16")));

PHP, 261 znaków

echo mb_convert_encoding("䱯牥洠楰獵洠摯汯爠獩琠慭整Ⱐ捯湳散瑥瑵爠慤楰楳捩湧⁥汩琬⁳敤⁤漠敩畳浯搠瑥浰潲⁩湣楤楤畮琠畴慢潲攠整⁤潬潲攠浡杮愠慬楱畡⸠啴⁥湩洠慤楮業⁶敮楡洬ⁱ畩猠湯獴牵搠數敲捩瑡瑩潮⁵汬慭捯慢潲楳楳椠畴⁡汩煵楰⁥砠敡⁣潭浯摯⁣潮獥煵慴⸠䑵楳⁡畴攠楲畲攠摯汯爠楮⁲数牥桥湤敲楴⁩渠癯汵灴慴攠癥汩琠敳獥⁣楬汵洠摯汯牥⁥甠晵杩慴畬污⁰慲楡瑵爮⁅硣数瑥畲⁳楮琠潣捡散慴⁣異楤慴慴潮⁰牯楤敮琬⁳畮琠楮⁣畬灡ⁱ畩晦楣楡⁤敳敲畮琠浯汬楴⁡湩洠楤⁥獴慢潲畭.","UTF-16");

Kodowanie $ s zawiera ciąg znaków

foreach(str_split(bin2hex($s),4)as $c)eval('echo"\u{'.$c.'}";');

Stara wersja PHP, 386 bajtów | Znaków

echo gzinflate(base64_decode("NZDBcUMxCERb2QI8v4rklmsKIIjvMCMJWQKPyw/KT25CwLL7PmxKg44VDcWqTSx1UBO/ga0vYRePCSo6dLH2O6RqNpeUXIBorGYFLm3ksnbWoiW6IxyVvlIe4pe0oNG9E6jqI+jAp0O6ttRG0/14ZknthkfoQrflMwrkJZPVydU6olZqbJfyHtKl+9KvpI4chlAab+nJrgB5yg+8bUkKF+iMdHJl1Y4pY8q39CIzg+fH02qMPCdpJ5NC1hKw1vpPKAMFzrgrOfo2hEEzi5gH3l8swyU2xmRgzCSccxxDC/neyBRjmhbpm+ImlUc56qCdG3aeykoosmTubrO6bdAGpIlj/XGNdvwA"));

4

C #, 337 333 331 znaków

_=>{var q="";foreach(var c in"潌敲彭灩畳彭潤潬彲楳彴浡瑥弬潣獮捥整畴彲摡灩獩楣杮敟楬ⱴ獟摥摟彯楥獵潭彤整灭牯楟据摩摩湵彴瑵江扡牯彥瑥摟汯牯彥慭湧彡污煩慵弮瑕敟楮彭摡浟湩浩癟湥慩Ɑ煟極彳潮瑳畲彤硥牥楣慴楴湯畟汬浡潣江扡牯獩湟獩彩瑵慟楬畱灩敟彸慥损浯潭潤损湯敳畱瑡弮畄獩慟瑵彥物牵彥潤潬彲湩牟灥敲敨摮牥瑩楟彮潶畬瑰瑡彥敶楬彴獥敳损汩畬彭潤潬敲敟彵畦楧瑡湟汵慬灟牡慩畴ⅲ䕟捸灥整牵獟湩彴捯慣捥瑡损灵摩瑡瑡湟湯灟潲摩湥ⱴ獟湵彴湩损汵慰煟極潟晦捩慩摟獥牥湵彴潭汬瑩慟楮彭摩敟瑳江扡牯浵ਡ")q=q+(char)(c&255)+(char)(c>>8);return q.Replace("!",".").Replace("_"," ");};

-4 znaki, zastępując .s po „pariatur” i „laborum” !przed połączeniem znaków do szerokich znaków i dodaniem nowej linii końcowej.

-2 znaki poprzez ponowne przypisanie wyjściowego var zamiast dołączania +=.

Jak to działa:

Łańcuch lorem ipsum został przekonwertowany na ten bałagan, zastępując .go !, dzięki _czemu, gdy znaki ascii są umieszczane obok siebie, aby uzyskać szeroki znak, każdy szeroki znak jest pojedynczym znakiem.

/*Func<object, string> Lorem = */ _=> // unused parameter
{
    // Output var
    var q = "";

    // Enumerate each wide char
    foreach (var c in "潌敲彭灩畳彭潤潬彲楳彴浡瑥弬潣獮捥整畴彲摡灩獩楣杮敟楬ⱴ獟摥摟彯楥獵潭彤整灭牯楟据摩摩湵彴瑵江扡牯彥瑥摟汯牯彥慭湧彡污煩慵弮瑕敟楮彭摡浟湩浩癟湥慩Ɑ煟極彳潮瑳畲彤硥牥楣慴楴湯畟汬浡潣江扡牯獩湟獩彩瑵慟楬畱灩敟彸慥损浯潭潤损湯敳畱瑡弮畄獩慟瑵彥物牵彥潤潬彲湩牟灥敲敨摮牥瑩楟彮潶畬瑰瑡彥敶楬彴獥敳损汩畬彭潤潬敲敟彵畦楧瑡湟汵慬灟牡慩畴ⅲ䕟捸灥整牵獟湩彴捯慣捥瑡损灵摩瑡瑡湟湯灟潲摩湥ⱴ獟湵彴湩损汵慰煟極潟晦捩慩摟獥牥湵彴潭汬瑩慟楮彭摩敟瑳江扡牯浵ਡ")
        // Split each wide char into two ascii chars
        q = q + (char)(c&255) + (char)(c>>8);

    // Restore the replaced periods and spaces
    return q.Replace("!",".").Replace("_"," ");
};


2

MATL , 354 znaków

'8 sxAI($ltZ>2<xa`vYf:s2e9]c&^KtD%e{C*XEpQ]]>dwmi>2;{sUCIZ{V(}Yj 7K&)|,%JD/Pz^:3$*@vVJw)4pgvz4s_$,%pVGu~|PS/Qr7pz5Z2[VV{Lyq}{l!yGiKNg.zFJxL75 sT1]eL2f3iVe~11!|6c+O9.kMWFQYvEp^w0p oH,?Ey"nbV>0g`#)kqTq""" z_AYmyJutvg:o9&AT{#(<42wu.b7" QoOn\#])]ISdH$yc{eM> .[~/`"#2:7C4Mk@eRW8L*_!xjo\cO)!LHK=g:P?&Uc];KdnE(%K7J-z9:7&rhxHl/KZ8\t_C|rT#%28[%+#u.?'F2Y2' ,.DEL'hZa

To dekoduje z base-94 (używając drukowalnych znaków ASCII, z wyjątkiem pojedynczego cudzysłowu, więc używane są tylko znaki Unicode do 126) na alfabet wymaganych znaków, utworzony przez większość małych liter, niektóre wielkie litery, spację, przecinek i kropkę.

Kompilator online zajmuje kilka sekund.

Wypróbuj online!


2

JavaScript (ES5), 342 znaków

c="remo ipsudlta,cngbq.UvxDhfE";"L"+"Qq©Úu[Qsx7Ķz`¾ƅ&Øxø§Ëƴ%ţ¾÷öm¿Zw¥ſøûƠtĭĚǎmĭöđnŔơxēǮŗĭ*x÷;ƚ:ȸƚņţǮ{XĩámɓŏƙâĚDUĚǎÁƚÂtĭŎݦ1mňŽ8ZUŽƜ-äļÝÁŌĪqu[Qqƙ¢3*ôĭ[ÞĵĪ%mÄſĘÚu[Q#èĭƝĘň®ŏØȅ˔Ż­#ÂƠoƈŅƆĭƂ§ÿĵĭƘƙ¢VôƠţÅƠqƙƂĔňǮjʨſňô¾Ơn[ēĭœq÷\"ĭĚǎI".split('').map(function(x){y=x.charCodeAt(0);return c[~~(y/27)]+c[y%27]}).join('')

Całkiem proste, więc jestem pewien, że jest miejsce na ulepszenia. Zakodowałem każdą parę znaków wyjściowych jako pojedynczy znak Unicode.


1
Potrzebujesz var ?
Paul Schmitz

Świetnie, ogoliłem te dodatkowe postacie. Dzięki!
Eric Dobbs

Jeśli używasz ES6, zamień join('')na join``. Jeśli nie, zmień język naJavaScript (ES5)
Paul Schmitz

Myślę, że możesz to zrobić y/27|0zamiast ~~(y/27)zaoszczędzić dwa bajty. Można również usunąć 0in x.charCodeAt(0).
ETHprodukcje

Ponadto .split('').map(function).join('')może być.replace(/./g,function)
ETHproductions

1

Galaretka , 300 znaków (niekonkurujących?)

“ḊḄr⁷ƤⱮx#y&Ọ¬½ẇṾƤẋRṠỊ/IṗIÞƝỊż,CA~ñ;ßɦ4ṿḷNVẸẆ`°ṄjJ⁽Ɱ!Æḋ"uƒ⁽ƙfƈÇœƓ®ḶẓƭƊȮ⁻w}Ġṙ(1€CÐ-ɼ#ȯjėȮoZœ°ȥạ_ẊƊaʠiẸṂṪẒ$ċⱮiẹOṠBṇḲ^*GƓŒA>żıWṭƤe&ėẠF6³ṂḲzlçÇṪġṂŻỵḢ⁴WJC⁽Ỵihıỵṃ¥ẏƬEỴ⁽#ḍʠḢ*^O[4)ỵZ5VoPĠƘṙḅß]<œ/ṅẸ% ḍ"Ɱ+¢¦ß÷⁵Ḍ³Ṅ¶2X|©dċÆṁḢƭṗM°`KǦɗỤɱṆȯƘkṅbṙ⁻l<t,ḟȮạżæ€ṠṣIȥCṘƥṁ©53ẒþØŻṁ£æƥ?¬ṿFæṘ⁴nụ’ṃ“Lrem ipsudlta,cngbq.UvxDhfEo

Wypróbuj online!

Kodowanie to Jelly .

Dzięki skompresowanym ciągom udało mi się go skompresować o 3 bajty.

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.