Maintenant que je connais mon ABC, ne viendras-tu pas jouer au golf avec moi?

46

Ecrivez un programme ou une fonction qui affiche ce texte exact, sans distinction de casse:

A, B, C, D, E, F, G,
H, I, J, K, L, M, N, O, P,
Q, R, S,
T, U, V,
W, X, Y, Z.

(Basé sur la chanson de l' alphabet que de nombreux enfants américains apprennent à mémoriser l'alphabet, bien que modifié pour plus de compressibilité.)

La sortie doit avoir exactement le même aspect que ci-dessus (là encore, insensible à la casse), mais peut contenir des espaces de fin sur chaque ligne et / ou des nouvelles lignes. Notez la période à la fin.

C'est le code-golf, donc le code le plus court en octets gagne.

ETHproductions
la source
4
Pour les langues basées sur les expressions rationnelles, considérez un aperçu de largeur 0/(?=[HQTW])/
Magic Octopus Urn
29
Je pensais que c'était H, I, J, K, LMNO, P?
Réintégrer Monica le
7
La dernière ligne ne devrait-elle pas se terminer par "Y et Z."?
KM.
@KM. Cela a été discuté dans le bac à sable et nous avons décidé de nous en tenir à cette version pour rendre le défi moins compliqué.
ETHproductions
6
Le golf semble ennuyeux. Le cricket c'est mieux.
Manoj Kumar

Réponses:

15

Vim, 42 , 40 frappes / octets

:h<_<cr>jjYZZP:s/./&, /g<cr>7f r<cr>9;.3;.3;.$ch.

Merci à Lynn et à sa réponse géniale vim pour le conseil de saisir l’alphabet de l’aide.

Merci à RomanGräf d'avoir économisé deux octets!

Explication:

:h<_<cr>                                      " Open up vim-help
        jj                                    " Move down two lines
          Y                                   " Yank this line (containing the alphabet)
           ZZ                                 " Close this buffer
             P                                " Paste the line we just yanked
              :s/./&, /g<cr>                  " Replace every character with that character followed by a comma and a space
                            7f                " Find the seven space on this line
                               r<cr>          " And replace it with a newline
                                    9;        " Repeat the last search (space) 9 times
                                      .       " Repeat the last edit (replace with a newline)
                                       3;     " Third space
                                         .    " Replace with newline
                                          3;  " Third space
                                            . " Replace with newline

Ensuite, nous déplaçons la fin de la ligne avec $, inversons un caractère chet insérons un point.

DJMcMayhem
la source
2
Vous ne devez pas convertir en majuscule. Le PO a déclaré "ce texte exact, insensible à la casse".
Roman Gräf
@ RomanGräf Merci pour le tuyau!
DJMcMayhem
Ha! Obtenir de l'alphabet de l'aide de vim est un génie! Le saviez-vous ou l'avez-vous relevé pour ce défi?
Christian Rondeau
3
@christianRondeau Je ne l'ai pas inventé. Lynn a fait dans cette réponse
DJMcMayhem
@ RomanGräf +1 pour utiliser ne doit pas
FantaC
12

05AB1E , 16 octets

Code

A',â79334S£»¨'.J

Explication:

A                  # Push the alphabet.
 ',â               # Cartesian product with ','.
    79334S         # Push [7, 9, 3, 3, 4].
          £        # Contigious substring, pushes the substrings [0:7], [7:7+9], 
                     [7+9:7+9+3], [7+9+3:7+9+3+3], [7+9+3+3:7+9+3+3+4].
           »       # Gridify, join the inner arrays with spaces and join those arrays
                     with newlines.
            ¨      # Remove the last character.
             '.J   # Append a '.'-character.

Utilise le codage CP-1252 . Essayez-le en ligne!

Adnan
la source
11

Utilitaires Bash + GNU, 36

  • 5 octets sauvés grâce à Neil.
echo {A..Y}, Z.|sed 's/[HQTW]/\n&/g'

Idéone.

Trauma numérique
la source
2
Pourquoi pas juste echo {A..Y}, Z.|sed 's/[HQTW]/\n&/g'?
Neil
@ Neil Ooh très bien! Merci!
Digital Trauma
11

JavaScript (ES6), 66 à 65 octets

Battre @Neil était impossible ... C'est pourquoi je l'ai fait. :-)

f=(i=10)=>i>34?"z.":i.toString(++i)+","+` 
`[9568512>>i-9&1]+f(i)

Golfé 1 octet grâce à un tour de @LevelRiverSt . L'utilisation String.fromCharCodeest 7 octets plus long:

f=(i=65)=>i>89?"Z.":String.fromCharCode(i,44,i%86%83%80%71?32:10)+f(i+1)

Comment ça fonctionne

Cela génère récursivement chaque caractère de l'alphabet de aà y, en utilisant .toString(). Une virgule est ajoutée après chaque lettre, plus une nouvelle ligne si 9568512>>i-9&1vaut 1 ou un espace sinon. Lorsque la récursion dépasse 34, c'est-à-dire z, la fonction revient simplement "z.".

ETHproductions
la source
Attendez qu'est-ce que cela fait même - explication pls? : 3
Rédigé le
10

Python 2.7, 67 66 63 octets

a=65;exec"print'%c'%a+',.'[a>89]+'\\n'[a%42%39%9^2:],;a+=1;"*26

Dennis a sauvegardé un octet.

Lynn
la source
Utiliser execau lieu de fordevrait sauvegarder un octet.
Dennis
6

Gelée , 19 à 18 octets

ØAp”,ṁ79334DR¤GṖ”.

Merci à @Adnan d'avoir joué 1 octet!

Essayez-le en ligne!

Comment ça fonctionne

ØAp”,ṁ79334DR¤GṖ”.  Main link. No arguments.

ØA                  Yield "ABCDEFGHIJKLMNOPQRSTUVWXYZ".
  p”,               Cartesian product with ','; append a comma to each letter.
             ¤      Combine the two links to the left into a niladic chain.
      79334D          Decimal; yield [7, 9, 3, 3, 4].
            R         Range; yield [[1, 2, 3, 4, 5, 6, 7], ..., [1, 2, 3, 4]].
     ṁ              Mold; reshape the array of letters with commata like the
                    generated 2D array.
              G     Grid; separate rows by spaces, columns by linefeeds.
               Ṗ    Pop; discard the last comma.
                ”.  Print the previous result and set the return value to '.'.
                     (implicit) Print the return value.
Dennis
la source
11
31 secondes? Dang ...
ETHproductions
5

JavaScript (ES6), 80 74 octets

_=>[...`ABCDEFGHIJKLMNOPQRSTUVWXYZ`].join`, `.replace(/[HQTW]/g,`
$&`)+`.`

Probablement possible de raccourcir cela avec atob / btoa si vous pouvez comprendre comment utiliser le codage ISO-8859-1. Edit: 6 octets enregistrés grâce à @RickHitchcock.

Neil
la source
1
@ RickHitchcock Oui, je viens de réaliser cela après avoir lu la réponse à PHP.
Neil
@ RickHitchcock Vous vouliez .join`, `? Mettez des barres obliques inverses avant les backticks. (Oui, le commentaire est différent, soupir ...)
Neil
5

Pyke, 23 19 17 octets

G\,J\.+2cu  /P

Essayez-le ici!

G\,J\.+        -    ",".join(alphabet)+"."
       2c      -   split(^, size=2)
            /  -  split_sized(^, V)
         u     -   yield list [7,9,3,3] (actual bytes `u%04%07%09%03%03`)
             P - print(^)
Bleu
la source
5

R, 83 71 octets

a=rbind(LETTERS[-26],","," ");a[3,7+3*c(0,3:5)]="\n";cat(a,"Z.",sep="")

Essayez-le en ligne!

Crée une matrice de 3 lignes (une avec les lettres, une avec les virgules et l’autre avec un espace ou une nouvelle ligne).

Edit : Merci Billywob!

planificateur
la source
cat(a,sep="")sauve quelques octets:a=rbind(LETTERS,","," ");a[3,7+3*c(0,3:5)]="\n";cat(a[,-26],"Z.",sep="")
Billywob
Merci! Cela a beaucoup aidé! L'utilisation directe de [-26]sur LETTERSenregistre un autre octet.
Plannapus
4

CJam, 26 octets

'A79333Ab{{',S2$)}*N\}/'.@

Interprète en ligne

'A                             Push 'A'
  79333Ab                      Push [7 9 3 3 3]
         {           }/        For each number n in the previous array...
          {      }*              Execute n times...
           ',S                     Push a comma and a space
              2$)                  Copy last letter and increment
                   N\            Place a newline under the letter on top
                       '.@     Push '.' and rotate
Sp3000
la source
4

Brainfuck, 117 octets

+[++[-<]-[->->]<]+++[->++>+++>+>+<<<<<--<<->>>]>+[[-<<<<<+.>-.+>.>>>]>[[-<+>]>]<<[<]<.>>]<<-[---<<<+.>-.+>.>]<<<+.>+.

Les quatre premières lignes ont chacune un espace de fin et le programme suppose des cellules de 8 bits. Essayez-le en ligne!

(Manipuler la dernière ligne est délicat ...)

Sp3000
la source
4

Perl, 37 octets

Crédits à @Dom Hastings pour cette solution (3 octets de moins que le mien, voir ci-dessous).

say+(map"$_, ".$/x/[GPSV]/,A..Y),"Z."

Courir avec -E(ou -M5.010) drapeau:

perl -E 'say+(map"$_, ".$/x/[GPSV]/,A..Y),"Z."'

Ma version précédente, 3 octets de plus (total de 40 octets):

perl -E '$_=join", ",A..Z;s/[HQTW]/\n$&/g;say"$_."'
Dada
la source
1
Approche légèrement différente (utilise toujours l'expression régulière ...) pour 37 octets:say+(map"$_, ".$/x/[GPSV]/,A..Y),"Z."
Dom Hastings
@DomHastings Nice one, Bravo. Et c'est plus beau d'avoir une déclaration au lieu de trois! ;-)
Dada
4

JavaScript (ES6), 66 64 octets

_=>`ABCDEFG
HIJKLMNOP
QRS
TUV
WXY`.replace(/./g,"$&, ")+"Z."

L'expression régulière correspond aux caractères, mais pas au retour chariot, aussi, en utilisant l'expression régulière, je peux ajouter le "," à chaque caractère.

Edit: Suppression de 2 caractères grâce à ETHProductions

Grax32
la source
1
Je ne sais pas pourquoi les autres golfeurs de JS n'ont pas opté pour cette solution. Ici, avoir un upvote.
Mama Fun Roll
1
Dang, gentil! Je pense que vous pouvez supprimer les parenthèses dans la regex si vous passez $1à $&.
ETHproductions
3

Cheddar, 70 octets

->[65@"71,72@"80,"QRS","TUV","WXYZ"].map(@.chars.join(", ")).vfuse+'.'

On dirait que ça ne devient pas plus court que ça. J'ai fait d'autres versions de cette méthode qui utilisent des méthodes assez intéressantes mais la plus courte

Essayez-le en ligne!

Explication

->                        // Function with no arguments
  [                       // Array, each item represents a line
   65@"71,                // See below on what @" does
   72@"80,
   "QRS",
   "TUV",
   "WXYZ"
  ].map(                  // On each item...
    @.chars.join(", ")    // Join the characters on ", "
  ).vfuse                 // Vertical fuse or join by newlines
  + '.'                   // The period at the end

L' @"opérateur est utilisé pour générer une chaîne de caractères à distance. Il génère une chaîne allant du code de caractère de gauche au code de droite.

Par exemple, 65est le code de caractère pour Aet 90pour Z. Faire 65 @" 90générerait de A à Z ou l'alphabet.

Downgoat
la source
3

C 112 102 81 octets

Merci à Cleblanc & LevelRiverSt!

i,c;main(){for(c=64;++c<91;)printf("%c%c%c",c,44+c/90*2,c=="‌​GPSVZ"[i]?++i,10:32)‌​;}
musarithmie
la source
Belle solution. vous pouvez économiser quelques octets, car 44 correspond à 1 de moins que ',' et 46 1 à moins de '.'
Cleblanc
Il n'est pas nécessaire de déclarer int et vous pouvez créer des entrées implicites également, ce n'est que 101 octetsi,c,d;main(){for(c=65;c<91;++c){if(c-"GPSVZ"[i])d=32;else d=10,++i;printf("%c%c%c",c,c-90?44:46,d);}}
cleblanc
Vous pouvez obtenir cette approche jusqu'à 82 octets: i,c;main(){for(c=64;++c<91;)printf("%c%c%c",c,44+c/90*2,c=="GPSVZ"[i]?++i,10:32);}. Notez que vous pouvez coller absolument n'importe quoi entre l' ?:opérateur d'un opérateur ternaire, même plusieurs expressions séparées par des virgules (la dernière est évaluée.)
Level River St
3

Brainfuck, 157 octets

+++++[>+>+++<<-]>>[->+>++++>+++>++<<<<]>----->+++++.>-.>++.<<<<<+[->>>+.>.>.<<<<<]+++++++++>>.<<[->>>+.>.>.<<<<<]<---[+>+++>>.<<[->>>+.>.>.<<<<<]<]>>>>+.>++.

Essayez-le en ligne

gtwebb
la source
3

Ruby, 56 54 octets

$><<(?A..?Y).map{|c|c+('GPSV'[c]?",
":", ")}.join+"Z."

La première ligne se termine par une nouvelle ligne.

Edit: sauvegardé deux octets en remplaçant 'A'..'Y'par ?A..?Y.

pgks
la source
3

Vim, 32 octets

26o<C-V><C-V>64,<Esc>r.V{g<C-A>8Jj9Jj3Jj.j4JcH<C-R>"

Laisse une ligne blanche à la fin, ce qui était autorisé, mais c'est bizarre d'être aussi maladroit. Pire encore, je termine en mode insertion. J'ai vu d'autres personnes le faire ici, alors je suppose que c'est permis? C'est sale.

  • 26o<C-V><C-V>64,<Esc>: Le premier <C-V>fait que le second insère littéralement. Le <C-V>64s que cela laisse dans le tampon sera transformé en points de code ASCII, puis en lettres. Virgule déjà dedans.
  • r.: Ne sera jamais à la fin, alors faites le .maintenant.
  • V{g<C-A>: Utilise l’incrément visuel pour transformer tous les 64s en points de code ASCII des lettres majuscules.
  • 8Jj9Jj3Jj.j4J: La ligne arbitraire rejoint. Le premier est 8Jau lieu de 7Jparce que nous avons affaire à la ligne blanche. Les 3Js répétés sont éligibles pour une répétition de points.
  • cH<C-R>": Les gens pensent généralement i<C-R>comme une pâte en mode insertion, mais plutôt comme une macro en mode insertion. Les choses comme <C-V>65se dérouleront comme si elles étaient tapées et interprétées comme un point de code décimal. Cela laisse une ligne supplémentaire (autorisée) à la fin et reste en mode insertion.
udioica
la source
4
si vous avez un problème avec une politique (ou une absence de politique), prenez-le en méta, pas dans une réponse.
Mego
2

PowerShell v3 +, 60 78 67 octets

-join(65..90|%{[char]$_+'.,'[$_-le89]+" "+"`n"*($_-in71,80,83,86)})

D'ACCORD. En fait, j'ai lu, compris et suivi les spécifications cette fois-ci. Promettre. :RÉ

Prend le tableau 65..90et les boucles sur chaque élément |%{...}. À chaque itération, nous construisons une nouvelle chaîne à l'aide de la concaténation, de l'indexation et de la multiplication.

Premièrement, prenons le nombre actuel et le charconvertissons pour en faire une lettre ASCII. Cela est concaténé avec un autre caractère, basé sur l'indexation dans la chaîne, '.,'que nous en soyons 90ou non (c.-à-d., À prendre en compte Z.tout en laissant le reste sous forme de virgules). Il s'agit d'une chaîne concaténée avec " "pour séparer les lettres des espaces, et d'une multiplication de chaîne "`n"basée sur la valeur booléenne pour déterminer si l'élément actuel est -inle tableau spécifié (c'est-à-dire, si nous devons concaténer un caractère de nouvelle ligne). La chaîne résultante est laissée sur le pipeline.

Ces chaînes sont encapsulées dans des parenthèses et -joinéditées ensemble dans une nouvelle chaîne, qui est également laissée sur le pipeline et implicite Write-Outputà la fin de l’impression du résultat. Comme nous avons `ndans la chaîne, elle est automatiquement convertie en nouvelles lignes lors de l'impression.

Nécessite v3 + pour l' -inopérateur. Dispose d'un espace de fin sur chaque ligne, ce qui est acceptable pour les spécifications du challenge.

Exemple

PS C:\Tools\Scripts\golfing> .\now-i-know-my-abc.ps1
A, B, C, D, E, F, G, 
H, I, J, K, L, M, N, O, P, 
Q, R, S, 
T, U, V, 
W, X, Y, Z. 
AdmBorkBork
la source
1
La période à la fin est manquante.
Downgoat
Ne devrait-il pas y avoir une virgule à la fin des quatre premières lignes?
Neil
@ Neil Bonne sauce. Je vais supprimer ceci jusqu'à ce que je puisse réellement comprendre la spécification.
AdmBorkBork
2

PHP, 62 octets

<?=preg_filter("# ([HQTW])#","\n$1",join(", ",range(A,Z)));?>.

seulement pour comparaison 87 octets

<?="A, B, C, D, E, F, G,\nH, I, J, K, L, M, N, O, P,\nQ, R, S,\nT, U, V,\nW, X, Y, Z.";
Jörg Hülsermann
la source
Vous pouvez enregistrer un octet en utilisant une nouvelle ligne à la place de \n.
Alex Howansky
Comme vous êtes autorisé à laisser des espaces à la fin de chaque ligne, vous pouvez enregistrer un octet en supprimant l’espace de la regex. Vous pouvez également enregistrer un octet en utilisant le paramètre ereg_replace (obsolète et supprimé dans la version 7.0), car il vous permet d'ignorer les délimiteurs dans l'expression régulière.
user59178
@ user59178 Je pourrais économiser 3 octets mais je voudrais éviter cela. Oui, l'espace de fin est autorisé. Je pourrais écrire comme regex "# (?=[HQTW])#"et raccourcir le remplacement aux "\n"mêmes octets et le rendre plus clair. Utiliser une fonction déconseillée peut dérouter les débutants. Et la rupture physique peut être mal interprétée sur d’autres systèmes qu’Unix. Vous pouvez le poster comme votre propre sugesstion.
Jörg Hülsermann
2

MATL, 38 29 octets

9 octets sauvés grâce à @Luis!

1Y2X{', '&Zc46h1[CEII]I*11hY{

Essayez-le en ligne!

Explication

1Y2     % Push the upper-case alphabet to the stack
X{      % Break the character array into a cell array (similar to a list)
        % where each element is a letter
', '&Zc % Combine back into a string with ', ' between each element
46h     % Append '.' (via ASCII code) to the end of the string
1       % Push the number 1
[CEII]  % Push the array: [7, 9, 3, 3]
I*      % Multiply this array by 3: [21, 27, 9, 9]  
llh     % Append an 11 to this array: [21, 27, 9, 9, 11] 
Y{      % Break our comma-separated list of characters into groups of this size
        % Implicitly display the result
Suever
la source
2

R, 146 octets

L=LETTERS
f=function(x,y=""){paste(x,collapse=paste0(", ",y))}
cat(f(c(f(L[1:7]),f(L[8:16]),f(L[17:19]),f(L[20:22]),f(L[23:26])),"\n"),".",sep="")

Explication:

LETTERSest prédéfini pour les lettres majuscules.
La ffonction sert à concaténer le vecteur x sur ,avec additionnel y(utilisé pour les nouvelles lignes).
Le chat est utilisé car il imprime \nen nouvelles lignes. fest appelé sur les lettres pour former des lignes, puis à nouveau sur les lignes pour former la sortie entière.

Probablement golfable - Je n'aime pas les multiples appels de f ...

pyjonk
la source
3
La sortie brute ne fait que 77 octets de long. L'impression directe pourrait être plus courte ...
Lynn
@ Lynn, je sais, mais je vois ici quelques possibilités pour jouer au golf.
pajonk
2

CJam, 31 octets

'[,65>", "*7933Ab{3*/(\:+}%N*'.

Explication:

'[,65>                             push uppercase alphabet
      ", "*                        ", " between all letters
           7933Ab                  push [7 9 3 3]
                 {3*/(\:+}%        slices of lengths 21, 27, 9, 9
                           N*'.    join slices with newlines, add final "."

Essayez-le en ligne

Neorej
la source
2

Julia, 71 octets

f()=join(join.(['A':'G','H':'P',"QRS","TUV","WXYZ"],[", "]),",\n")*"."

Nécessite 0,5 ou plus pour la diffusion .()

Lyndon White
la source
D'une part, cela n'a actuellement pas de période de fin, et n'a-t-il pas besoin d'une printdéfinition / function? D'autre part, ne pas enregistrer joindans une variable enregistre un octet.
Sp3000
Mon mauvais manque le ".", Et merci pour le pointeur join. J'ai raté le compte. L'exécution du programme renvoie la chaîne. Un programme renvoyant une chaîne n'est-il pas une sortie valide? (Ou est-ce uniquement les fonctions qui sont autorisées à renvoyer des éléments à compter en tant que sortie? Si f()=c'est plus court que ça print())
Lyndon White
Bien sûr, f()=ou tout ()->va bien - je pense que l’idée est que les fonctions sont assignables et peuvent être exécutées plusieurs fois. En revanche, il s’agirait d’un extrait de code.
Sp3000
2

Cheddar, 57 octets

->(65@"90).sub(/[GPSV]/g,"$0
").sub(/[^Z\n]/g,"$0, ")+"."

Essayez-le en ligne! N'est-ce pas beau? C'est un joli rectangle.

Deux substitutions de regex. (65@"90)est l'alphabet majuscule, .sub(/[GPSV]/g,"$0\n")remplace GPSVpar lui-même et "\n", .sub(/[^Z\n]/g,"$0, ")remplace tous les Zcaractères non newline et par lui-même et ", ", et "."ajoute une finale ..

Conor O'Brien
la source
1
Belle technique, et bon boulot sur le golf Downgoat;)
ETHproductions
2

Japt, 24 octets

;B¬qJ+S r"[HQTW]"@R+XÃ+L

Testez-le en ligne!

Comment ça fonctionne

;                        // Reset various variables. B is set to "ABC...XYZ", J is set to ",", and L is set to ".".
 B¬                      // Take the uppercase alphabet and split into chars.
   qJ+S                  // Join with ", ".
        r"[HQTW]"        // Replace each H, Q, T, or W with
                 @R+XÃ   //   a newline plus the character.
                      +L // Append a period to the result.
                         // Implicit: output last expression
ETHproductions
la source
2

Java, 116 109 105 104

String f(){String s="";for(char c=65;c<91;)s=s+c+(c>89?46:',')+("GPSV".indexOf(c++)<0?' ':10);return s;}

Ungolfed:

String f() {
  String s = "";
  for (char c = 65; c < 91;) {
    s = s + c
      + (c > 89 ? 46 : ',')
      + ("GPSV".indexOf(c++) < 0 ? ' ' : 10);
  }
  return s;
}

la source
Vous pouvez jouer au golf avec 7 octets: les trois ||à |(-3); passer c==90à c>89(-1); passer '.'à 46(-1); et passer '\n'à 10(-2).
Kevin Cruijssen
@KevinCruijssen merci, j'ai essayé d'utiliser des décimales, mais il semble que si je remplace les deux constantes de caractère dans un texte ternaire, le type d'expression est modifié en entier, ce qui le casse. Changer une constante fonctionnait et effaçait quelques octets.
2
@ KevinCruijssen merci. Si j'avais assez de café en moi, je me serais rappelé de le mettre à jour moi-même.
1
2 octets supplémentaires: "GPSV".contains(""+c)au lieu de c==71|c==80|c==83|c==86.
TNT
1
@TNT, j'ai pu faire un peu mieux. Je savais que cette partie pourrait être améliorée, merci pour la poussée dans la bonne direction.
1

q, 46 octets

-1@'(", "sv/:0 7 16 19 22_,:'[.Q.A]),'",,,,.";
Skeevey
la source
1

Retina, 43 octets


Z
{2`
$`
}T01`L`_L
.
$&, 
[HQTW]
¶$&
, $
.

La nouvelle ligne est importante. Essayez-le en ligne!

C'est la première fois que j'utilise Retina. Tous les conseils relatifs au golf sont donc appréciés ...

ETHproductions
la source
1

Pyth, 25 octets

+Pjmj\ dc*G\,j94092 23)\.

Un programme qui imprime le résultat sur STDOUT.

Essayez-le en ligne

Comment ça fonctionne

+Pjmj\ dc*G\,j94092 23)\.  Program. Input: none
          G                Yield string literal'abcdefghijklmnopqrstuvwxyz'
         * \,              Cartesian product of that with ',', yielding a list of
                           characters with appended commas
             j94092 23)    Yield the integer 94092 in base-23, giving [7, 16, 19, 22]
        c                  Split the comma-appended character list at those indices
   mj\                     Join each element of that on spaces
  j                        Join that on newlines
 P                         All but the last element of that, removing trailing ','
+                      \.  Append '.'
                           Implicitly print
TheBikingViking
la source