PROGRAMOWANIE ZESPOŁÓW I KODÓW ____


45

Wejście

Niepusty kodowany ciąg znaków składający się z drukowalnych znaków ASCII (w zakresie 32-126), w którym niektóre brakujące litery zostały zastąpione _.

Wynik

Dekodowany ciąg o tej samej długości ze wszystkimi literami zapisanymi małymi literami, w tym brakującymi.

W jaki sposób?

Edycja: Jak wspomniano w komentarzach @Deusovi, jest to wariant szyfru Bacona .

  • Zbierz wszystkie litery z oryginalnego ciągu i pogrupuj je według 5. Dodatkowe litery, które nie mieszczą się w pełnej grupie 5, są ignorowane.
  • Konwertuj każdą grupę na binarną: małe litery = 0 , wielkie litery = 1 . To prowadzi do listy liczb całkowitych.
  • Użyj każdej wartości N na tej liście, aby zastąpić każdą _w oryginalnym ciągu N-tą literą alfabetu (z indeksowaniem 0), w kolejności pojawiania się.

Przykład: prOGraMMIng PuZZleS & cOde ____

prOGr --> 00110 -->  6 -->  7th letter = 'g'
aMMIn --> 01110 --> 14 --> 15th letter = 'o'
gPuZZ --> 01011 --> 11 --> 12th letter = 'l'
leScO --> 00101 -->  5 -->  6th letter = 'f'

Zastępując brakujące litery i konwertując wszystko z powrotem na małe litery, odsłonięty zostaje oryginalny ciąg:

programming puzzles & code golf

To jest oczekiwany wynik.

Wyjaśnienia i zasady

  • Brakujące litery z pewnością pojawią się na końcu łańcucha. Bardziej formalnie: nigdy nie będzie żadnej litery po pierwszej _w ciągu wejściowym. Mogą jednak występować inne drukowalne znaki ASCII, takie jak spacje i znaki interpunkcyjne.
  • Dane wejściowe z pewnością nie zawierają niepotrzebnej dużej litery: wszystkie duże litery to bity ustawione na 1, które są wymagane do odkodowania brakujących liter. Cała reszta jest zapisana małymi literami.
  • Gwarantowany ciąg wejściowy. Szczególnie:
    • Zawsze będzie zawierać wystarczającą liczbę pełnych grup 5 liter, aby zdekodować podkreślenia.
    • Binarnie zakodowane liczby całkowite z pewnością mieszczą się w zakresie [0–25] .
  • W _łańcuchu wejściowym może nie być wcale , w takim przypadku wystarczy zwrócić dane wejściowe.
  • To jest , więc wygrywa najkrótsza odpowiedź w bajtach!

Przypadki testowe

Input : hello!
Output: hello!

Input : helLO, worl_!
Output: hello, world!

Input : i aM yoUr faTh__.
Output: i am your father.

Input : prOGraMMIng PuZZleS & cOde ____
Output: programming puzzles & code golf

Input : Can YOu gUesS tHE ENd oF This ____?
Output: can you guess the end of this text?

Input : THe qUICk brown FOx JUMps oVEr the la__ ___.
Output: the quick brown fox jumps over the lazy dog.

Input : RoadS? wHERe we're goinG WE doN't need _____.
Output: roads? where we're going we don't need roads.

Input : thE greatESt Trick thE DeVIl EVer PUllEd wAs CONvInciNg tHe WorLD h_ ____'_ _____.
Output: the greatest trick the devil ever pulled was convincing the world he didn't exist.

Niektóre dodatkowe przypadki testowe:

Input : BInar_
Output: binary

Input : 12 MonKey_
Output: 12 monkeys

Input : hyPerbolIZ__
Output: hyperbolized

Input : {[One Last Test ca__]}
Output: {[one last test case]}

Czy powinniśmy brać pod uwagę tylko tyle grup po 5, ile jest podkreślonych danych wejściowych?
Esolanging Fruit

W takim przypadku reguła, gdy nie ma _łańcucha wejściowego, jest trochę szczególnym przypadkiem.
Esolanging Fruit

1
Ooch, szyfr bekonowy!
Deusovi

1
@SztupY Ponieważ The input is guaranteed not to contain any useless capital letterw przypadku braku podkreślenia nie będzie też dużej litery.
Laikoni

1
@KirillL. Tak, wszystko w środku [32-126]. Dodałem inny przypadek testowy.
Arnauld

Odpowiedzi:


19

05AB1E , 18 bajtów

Kod:

áS.u5ôJC>.bv'_y.;l

Wykorzystuje kodowanie 05AB1E . Wypróbuj online!

Wyjaśnienie:

á                       # Remove non-letters from the input string.
 S                      # Split the result into individual characters.
  .u                    # Check if is uppercase for each character.
    5ôJ                 # Split into binary numbers of length 5.
       C                # Convert from binary to decimal.
        >               # Add one.
         .b             # Map 1 → A, 2 → B, 3 → C, ..., 25 → Y, 26 → Z.
           v            # For each letter:
            '_y.;       #   Replace the first occurrence of '_' with the current letter.
                 l      #   Convert the string to lowercase.


8

Perl 5 -pF -MList::Util=sum, 75 bajtów

@a=grep!/\W|\d/,@F;s!_!(a..z)[sum map{a gt shift@a&&16/2**$_}0..4]!eg;$_=lc

Wypróbuj online!

Wyjaśnienie:

  • -pFwczytuje wiersz danych wejściowych do zmiennej $_i dzieli na znaki w tablicy @F.
  • @a=grep!/\W|\d/,@Fustawia tablicę @arówną tym członom @F, które nie spełniają wyrażenia regularnego \W|\d. \Woznacza wszystko oprócz liter, cyfr i _; \dto liczby. Podobnie \W|\djest z literami i _, i @ama wszystkie litery i _znaki. Skończymy, nigdy nie badając _postaci @a. (Należy pamiętać, że działa to tylko dlatego, że wejście jest gwarantowane ASCII.)
  • map{a gt shift@a&&16/2**$_}0..4robi następujące dla 0 do 4: Przesuwa następny element @a, skraca go i ocenia, czy ajest asciibetycznie większy niż ten element (tj. czy ten element jest pisany wielkimi literami). Jeśli tak, &&to nie ulega zwarciu, więc otrzymujemy 16 podzielone przez 2 do mocy wartości wejściowej (od 0 do 4). W przeciwnym razie &&nastąpi zwarcie i otrzymamy 0. mapzwraca listę pięciu liczb sum, która dodaje je.
  • To jest element, którego chcemy z listy a..z, i to właśnie otrzymujemy (a..z)[…].
  • s!_!…!egkonwertuje każdy _z $_kolei na odpowiednią literę.
  • $_=lckonwertuje $_na małą wersję i -pdrukuje ją.


5

Galaretka ,  28 27  26 bajtów

-1 dzięki Erikowi Outgolfer i dylnan

Niezbyt przyjazne dla galaretki wyzwanie!

ḟŒs$Ƈ<”[s5Ḅ+97Ọż@ṣ”_$FṁLŒl

Monadyczny link przyjmujący i zwracający listy znaków.

Wypróbuj online!

W jaki sposób?

ḟŒs$Ƈ<”[s5Ḅ+97Ọż@ṣ”_$FṁLŒl - Link: list of characters    e.g. "MfUNE_?"  (shorthand for ['M','f','U','N','E','_','?'])
    Ƈ                      - filter keep each if:
   $                       -   last two links as a monad:
 Œs                        -     swap-case
ḟ                          -     filter discard
                           - ...i.e. keep A-Z,a-z since they change when the case is swapped
                           -                                  "MfUNE"
      ”[                   - literal character                '['
     <                     - less than? (i.e. is upper-case?) [1,0,1,1,1]
        s5                 - split into fives                 [[1,0,1,1,1]]
          Ḅ                - from base two (vectorises)       [[23]]
           +97             - add (vectorises) ninety-seven    [[120]]
              Ọ            - from ordinals (vectorises)       [['x']]
                    $      - last two links as a monad:
                  ”_       -   literal character              '_'
                 ṣ         -   split at                       [['M','f','U','N','E'],['?']]
               ż@          - swapped @rgument zip             [[['M','f','U','N','E'],'x'],['?']]
                     F     - flatten                          "MfUNEx?"
                       L   - length (of input)                7
                      ṁ    - mould like                       "MfUNEx?"
                           - ...removes any excess characters
                        Œl - lower-case                       "mfunex?"

5

Siatkówka , 91 90 bajtów

T`l`a
T`L`A
[^Aa]

L`.{5}
A
aA
+`Aa
aAA
+T`_lA`l_`[^A]A
^
$+¶
+`_(.*)¶a+(.)
$2$1
0G`
T`L`l

Wypróbuj online! Wyjaśnienie:

T`l`a
T`L`A
[^Aa]

Przetłumacz małe ai duże litery na A, usuwając wszystko inne.

L`.{5}

Podziel Aas na grupy po 5.

A
aA
+`Aa
aAA

Konwertuj z binarnego na jednorzędowy, traktując Ajako 1 i ajako 0. Ponieważ Aapierwotnie było 5 s, pozostało 5 as plus kilka As zależnie od pożądanej pozycji w alfabecie.

+T`_lA`l_`[^A]A

Zwiększ ostatni azgodnie z liczbą kolejnych As.

^
$+¶

Przygotuj oryginalne wejście.

+`_(.*)¶a+(.)
$2$1

Zamień dowolne _s na kolejną zdekodowaną literę.

0G`

Usuń wszystkie zapasowe zdekodowane litery.

T`L`l

Wszystko małymi literami.

Retina 0.8.2 , 117 bajtów

.+
$&¶$&
T`L`l`^.*
T`l`a`.*$
T`L`A
T`aAp`aA_`.*$
(.*¶)?.{5}
$&;
A
aA
+`Aa
aAA
+T`_lA`l_`[^A]A
+`_(.*¶)a+(.);
$2$1
1G`

Wypróbuj online! Wyjaśnienie:

.+
$&¶$&

Zduplikuj dane wejściowe.

T`L`l`^.*

Pierwsza kopia ma małe litery.

T`l`a`.*$

Przetłumacz małe litery ana drugą kopię.

T`L`A

Przetłumacz wielkie litery na A. Muszą być w drugiej kopii, ponieważ pierwsza kopia była już pisana małymi literami.

T`aAp`aA_`.*$

Usuń wszystko inne w drugiej kopii.

(.*¶)?.{5}
$&;

Podziel drugą kopię (teraz tylko Aas) na grupy po 5.

A
aA
+`Aa
aAA
+T`_lA`l_`[^A]A
+`_(.*¶)a+(.);
$2$1
1G`

Odkoduj litery i wstaw je jak poprzednio.


5

APL (Dyalog Unicode) , 46 bajtów SBCS

Anonimowa lambda, zakłada ⎕IO(indeks pochodzenia) 0.

{_'_'=⊢⋄819A[2⊥⍉(+/_⍵)5A∊⍨⍵∩A,819A←⎕A]@_⍵}

Wypróbuj online!

{... ... } funkcji dwóch oświadczenie; jest argumentem, oddziela instrukcje

 argument (funkcja no-op)
'_'= gdzie równa się podkreśleniu (tj. boolowskiej funkcji odwzorowania)
_← przypisuje tę funkcję do_

A[… Umieść ]@_⍵ następujące znaki A w pozycjach podkreślenia w argumencie
  ⎕A wielkimi literami A alfabet
  A← przypisuje to do A
  819⌶ małych liter ( 819 ≈ BIg , bez żadnego lewego argumentu oznacza, że ​​nie jest duży, tj. Małe litery),
  A, dodaje wielkie litery; daje nam to wszystkie litery
  ⍵∩ przecięcia argumentu i to; tylko litery argumentu,
  A∊⍨ które z nich są członkami wielkich liter; wielkie bity
  (... )5⍴r eshape że na następującą liczbę wierszy i kolumn: pięć
   _⍵ maską podkreślenia w argumencie
   +/ suma tego; liczba podkreśleń
   transponuj (aby traktować każdy wiersz jako liczbę, a nie pozycję bitową),
  2⊥ oceniaj wszystko jako
819⌶ małe litery base-2


5

Scala , 189 bajtów

def f(s:Array[Char])={var j=0;s.zipWithIndex.collect{case(95,i)=>s(i)=(Integer.parseInt(s.filter(_.isLetter)slice(j,j+5)map(k=>if(k<91)1 else 0)mkString,2)+97)toChar;j+=5};s.map(_.toLower)}

Wypróbuj online!

Wyjaśnienie:

def f(s: Array[Char]) = {                // takes a String in input
  var j = 0                              // j stores at which block of 5 letters we're currently at
  s.zipWithIndex.collect {               // Array('h', 'e', ...) => Array(('h', 0) ('e', 1), ...) and we apply a collect transformation (filter/map)
    case (95, i) =>                      // we only handle cases where the char is '_' (95)
      s(i) = (                           // we modify the char at index i with the following
        Integer.parseInt(                // Integer.parseInt("00110", 2) = 6
          s                              //
            .filter(_.isLetter)          // filter out non letter chars (spaces, punct, figures, ...) from the input string (thanks @Arnauld for the fix)A
            .slice(j, j+5)               // "substring" the array to the block of 5 letters in question
            .map(                        // map on the current block of 5 letters
              k =>                       // the index of the next char in the block f 5 (e.g. 13)
                if (k < 91) 1 else 0     // if the current char is upper case (<91) then we replace it by a bit true, otherwise by a bit false
            )mkString,                   // Array(0, 1, 1, ...) => "011..."
          2                              // cast string to binary
        )                                //
        + 97                             // +97 to create a lower case char
      )toChar                            // cast from int to char
      j += 5                             // update the starting index of the next block of 5 letters
    }                                    //
  s.map(_.toLower)                       // return the updated seq of chars all in lower case
}                                        //


4

Galaretka , 26 bajtów

xn¥Œs<”[s5Ḅ‘ịØaṛi”_ḟ0Ɗ¦ƒŒl

Wypróbuj online!

Inne podejście niż Jonathan Allan. EDYCJA: Tak więc najwyraźniej myślałem o takiej samej redukcji bajtów jak Jonathan Allan, więc nie będzie bolało, gdybym ponownie wspomniał jego imię.



3

Czysty , 180 ... 150 bajtów

import StdEnv
?s=['a'+sum[i\\i<-:""&c<-s|c<'a']: ?(drop 5s)]
@['_':b][x:y]=[x: @b y]
@[a:b]z=[toLower a: @b z]
@e _=e
$s= @s(?(filter isAlpha s))

Wypróbuj online!

Definiuje funkcję $ :: [Char] -> [Char]z @ :: [Char] [Char] -> [Char]jako pomocnik zastąpić podkreślenia, a ? :: [Char] -> [Char]jako pomocnika do generowania znaków zastępczych.


Jak działa i<-:""część? Czy znaki są domyślnie konwertowane na liczby podczas ich sumowania lub dodawania?
Laikoni

@Laikoni nie, nie ma niejawnej konwersji. Możesz jednak dodawać i odejmować znaki.
tragiczny


3

R , 153 135 113 bajtów

function(s,S=utf8ToInt(s)){S[S==95]=2^(4:0)%*%matrix(S[S%in%c(65:90,97:122)]<95,5)+97
cat(tolower(intToUtf8(S)))}

Wypróbuj online!

Wydaje niektóre ostrzeżenia przy użyciu, matrixale nie powinno to wpływać na wynik. Wydaje również ostrzeżenia, ponieważ [<-przypisanie domyślnie usunie przypisane obce obiekty.

40 (!) Bajtów w dół dzięki ulepszeniom JayCe


Nie sądzę, że potrzebujesz,length(L)%/%5
JayCe

Nie ma też potrzeby definiowania L?
JayCe

@JayCe, dobrze, dzisiaj dowiedziałem się, że [<-wyrzucą elementy poza długość indeksów ...
Giuseppe

Ja też właściwie!
JayCe


3

C (gcc) , 111 109 101 100 bajtów

Edycja: Dodano małą literę dla komentarza @ FrownyFrog; dzięki Lynn, Christoph i user5329483 za sugestie!

f(s,t,i)char*s,*t;{for(t=s;t=strchr(t,95);*t=i+1)for(i=3;i<64;s++)isalpha(*s)?i=2*i|*s<97,*s|=32:0;}

Wypróbuj online!


Możesz zapisać 2 bajty za pomocą i+=i+(*s<97).
Lynn

Możesz znieść j, wprowadzając bit znacznika ii przepisując drugi dla as for(i=1;i<32;s++). I zrekompensuj dodatkowe 32 w zewnętrznej części. Jako nowicjusz tutaj liczę siedem bajtów zapasowych.
user5329483

Znaleziono kolejny bajt: for(i=3;i<96;s++)sprowadza 65 do liczby jednocyfrowej, alias 1.
user5329483

2

Idź, 219 217 192 210 209 156 bajtów

Zaoszczędź 25 bajtów dzięki @Lynn! Zaoszczędź 53 bajty dzięki @ovs!

Musiałem stracić 18 bajtów z powodu błędu w ciągach znaków bez podkreślników :(

func p(s string){b:=0;n:=0;for _,c:=range s{if IsLetter(c){b+=b;if IsUpper(c){b+=1};n++;s=g.Replace(s,"_",string('a'+b%32),(5-n%5)/5)}};Print(g.ToLower(s))}

Wypróbuj online!


2

Stax , 22 bajty

â╟▓ïMeee¶▐f◄┴≈┘n╛äyΩ○N

Uruchom i debuguj

Ogólne podejście polega na zastępowaniu wyrażeń regularnych "_"za pomocą funkcji zwrotnej, która wycina litery danych wejściowych w celu obliczenia każdego znaku zastępczego.

v       convert to lower case
'_      "_" string literal
{       begin block for regex replacement
  yVl|& all the letters only from the original input
  5/    split into chunks of 5
  i@    keep the ith one, where i is the 0-based number of times this block has run
  {97<m map 5-letter chunk to bits to indicate which are lowercase
  :b    decode as 5-bit integer
  97+]  add 97 and wrap in array to convert to lower case character
}       end block for regex replacement
R       do regex replacement

Uruchom ten


1

Czerwony , 247 bajtów

func[s][a: charset[#"a"-#"z"#"A"-#"Z"]v: copy""parse s[any[copy c a(append v to-string c)|
skip]]k: 0 t: copy""repeat n(length? v)/ 5[c: 0 p: 16
loop 5[if v/(k: k + 1) <#"a"[c: c + p]p: p / 2]append t#"a"+ c]foreach c
t[replace s"_"c]lowercase s]

Wypróbuj online!

Bardziej czytelny:

f: func[s][
    a: charset[#"a"-#"z"#"A"-#"Z"]
    v: copy ""
    parse s[any[copy c a(append v to-string c)| skip]]
    k: 0
    t: copy ""
    repeat n (length? v) / 5[
        c: 0
        p: 16
        loop 5[
            if v/(k: k + 1) < #"a" [c: c + p]
            p: p / 2
        ]
        append t #"a" + c
    ]
    foreach c t[replace s "_" c]
    lowercase s
]

1

Java 10, 186 bajtów

s->{var b="";for(int i=0,c;i<s.length();)if((b+=(c=s.charAt(i++))>64&c<91?1:c>96&c<123?0:"").length()>4)s=s.replaceFirst("_",(char)(97+Byte.valueOf(b,2))+(b=""));return s.toLowerCase();}

Wypróbuj online.

Wyjaśnienie:

s->{                            // Method with String as both parameter and return-type
  var b="";                     //  Binary-String, starting empty
  for(int i=0,c;i<s.length();)  //  Loop over the characters of the input-String
    if((b+=(c=s.charAt(i++))>64&c<91?
                                //   If the current character is a lowercase letter:
            1                   //    Append "1" to the binary-String
           :c>96&c<123?         //   Else-if it's an uppercase letter:
            0                   //    Append "0" to the binary-String
           :                    //   Else (not a letter):
            "")                 //    Append nothing to the binary-String
       .length()>4)             //   And if the length is now 5:
      s=s.replaceFirst("_",     //    Replace the first "_" in the input-String with:
           (char)(97+Byte.valueOf(b,2))
                                //     The binary-String as character
           +(b=""));            //    And reset the binary-String
  return s.toLowerCase();}      //  Return the modified input-String as lowercase


1

Japt, 25 bajtów

r'_@r\L mè\A sTT±5 ÍdIÄÃv

Spróbuj


Wyjaśnienie

r'_                           :Replace underscores
   @                          :Pass each match through a function
    r                         :  From original input remove
     \L                       :    /[^a-zA-Z]/g
        m                     :  Map
         è                    :    Count
          \A                  :      /[A-Z]/g
             s                :  Slice
              T               :    From index T (initially 0)
               T±5            :    To index T+=5
                   Í          :  Convert from base-2 string to base-10 integer
                     IÄ       :  Add 64+1
                    d         :  Get character at that codepoint
                       Ã      :End function
                        v     :Lowercase

1

Pyth, 36 bajtów

Km@Gim!}kGd2c@+r1GGQ5VQp?qN\_.(KZr0N

Wypróbuj tutaj

Wyjaśnienie

Km@Gim!}kGd2c@+r1GGQ5VQp?qN\_.(KZr0N
             @+r1GGQ                   Get the letters from the input...
            c       5                  ... in chunks of 5.
 m        d                            For each chunk...
     m!}kG                             ... check if each letter is uppercase...
    i      2                           ... converted to binary...
  @G                                   ... and get the corresponding letter.
                     VQp               For each character in the input...
K                       ?qN\_.(KZ      ... if the character is '_', replace it...
                                 r0N   ... otherwise, lowercase it.

1

Python 3.5 , 296 bajtów

u=input();f=u.find('_');m=''.join([c for c in u if c.isalpha()]);z=[chr(int(''.join(['0'if o.islower() else'1' for o in l]),2)+65)for l in[m[h:h+5]for h in range(0,len(m),5)]if len(l)==5];[z.insert(v,d)for v,d in enumerate(u[f:])if d!="_"];u=list(u);u[f:]=z[:len(u[f:])];print(''.join(u).lower())

Wypróbuj online

Pierwszy kod golfa :)

(Wiem, że nie jest to małe bajty, po prostu dobrze się bawiłem, tworząc 1-liniowy kod)

Oto wyjaśnienie:


Wprowadzane przez użytkownika

u = input ()


Znajduje indeks pierwszego _ w ciągu i przechowuje go

f = u.find („_”)


usuwa ciąg wszystkich znaków innych niż alfa

m = ''. join ([c for c in u if c.isalpha ()])


Dzieli ciąg alfa na tablicę, w której każdy element składa się z 5 znaków

Dawny. [„THeqU”, „ICkbr”, „ownFO”, „xJUMp”, „soVEr”, „thela”]

Następnie konwertuje małe litery na 0 i wielkie litery na 1

Dawny. [„11001”, „11000”, „00011”, „01110”, „00110”, „00000”]

i konwertuje ciąg binarny na liczbę całkowitą, dodaje 65 i konwertuje to na znak

Dawny. [„z”, „y”, „d”, „o”, „g”, „a”]

z = [chr (int (''. join (['0' if if o.islower () else '1' for o in l]), 2) +65) for l in [m [h: h + 5] dla hw zakresie (0, len (m), 5)] jeśli len (l) == 5]


znajduje wszystkie znaki po pierwszym _ i wypycha je do tablicy z w odpowiednich miejscach (zdefiniowanych powyżej)

Dawny. [„z”, „y”, „”, „d”, „o”, „g”, „.”, „a”]

[z.insert (v, d) dla v, d w wyliczeniu (u [f:]) if d! = "_"]


podziel nasz ciąg na listę znaków

u = lista (u)


pokrój nasz ciąg od pierwszego _ do końca listy i zastąp go tablicą z. Musiałem także pociąć tablicę z na długość podzielonego łańcucha od pierwszego _ do końca, ponieważ dostałem dodatkowy znak w leniwym psie („a” na końcu powyższych przykładów)

u [f:] = z [: len (list (u [f:]))]


* wydrukuj odpowiedź *

print (''. join (u) .lower ())



Gra w golfa to coś więcej niż tylko wszystko na jednej linii. 165 bajtów
Jo King

Możesz usunąć przestrzeń między o.islower()i else, a ja myślę '1'i for. Możesz także zmienić if d!="_"na if"_"!=d, ale powyższy komentarz już to robi.
Zacharý

1

Haskell , 165 bajtów

g""
import Data.Char
f t(x:s)('_':r)=x:f t s r
f[0,a]s r=g(s++[chr a])r
f[n,a]s(c:r)=toLower c:f[div n$1+sum[1|isAlpha c],a+sum[n|isUpper c]]s r
f _ s e=e
g=f[16,97]

Wypróbuj online! Przykładowe użycie: g"" "BInar_"daje "binary".


1

PowerShell , 121 bajtów

switch -r($args|% t*y){_{$_=$a[$n++]+97}[a-z]{$x+=$x+($_-le96);if(!(++$i%5)){$a+=,$x;$x=0};$_=$_-bor32}.{$r+=[char]$_}}$r

Wypróbuj online!

Mniej golfa:

switch -Regex ($args|% toCharArray){
    _ {                     # is underscore
        $_=$a[$n++]+97      # get a char from the array of letter
    }

    [a-z] {                 # is letter
        $x+=$x+($_-le96)    # $x=2*$x+($_-le96)
        if(!(++$i%5)){      # if(++$i%5 -eq 0)
            $a+=,$x         # add an element to the array of letters
            $x=0            # init
        }
        $_=$_-bor32         # to lower
    }

    . {                     # is any char ('_' and letters included)
        $r+=[char]$_        # add the char to result
    }
}
$r

0

Perl 5 -p , 78 bajtów

for$h(s/\W|\d//gr=~y/a-z/0/r=~y/A-Z/1/r=~/.{5}/g){s%_%chr 65+oct"0b$h"%e}$_=lc

Wypróbuj online!


Naprawiłem to z 3 dodatkowymi bajtami, co sprawia, że ​​twoja odpowiedź jest nieco lepsza zgodnie z obecnymi zasadami.
Xcali

Nie lepiej, ale inaczej. Każdy język + opcje są rozpatrywane osobno, nie konkurując z tym samym językiem + innymi opcjami, jak rozumiem.
msh210
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.