Reverse Boustrophedon Text


19

Le boustrophédon est un type de texte bidirectionnel où les lignes successives alternent entre la lecture de gauche à droite et de droite à gauche. La direction des caractères était également reflétée par rapport à la direction de lecture. Dans les systèmes d'écriture à boustrophédon inversé, les caractères étaient tournés de 180 au lieu d'être mis en miroir.

Défi

Écrivez un programme / une fonction qui accepte une chaîne de texte et un certain nombre de colonnes, et génère la chaîne formatée dans le nombre spécifié de colonnes avec des lignes alternées inversées.

Contribution

Votre programme doit accepter deux arguments:

  • S, la chaîne de texte à formater
  • N, le nombre de colonnes

Production

Votre programme doit produire S enveloppé dans N colonnes avec des lignes alternées inversées à 180 degrés.

  • Le sens de lecture de la première ligne est toujours de gauche à droite.
  • Ne vous inquiétez pas de l'endroit où placer les sauts de ligne, les lignes peuvent être divisées en n'importe quel caractère, aucune hypénation des mots n'est requise.
  • Vous pouvez supposer que la chaîne d'entrée ne contiendra aucun saut de ligne.

Voici les personnages que votre programme devrait prendre en charge avec leurs homologues inversés:

Uppercase:
ABCDEFGHIJKLMNOPQRSTUVWXYZ
∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Z

Lowercase:
abcdefghijklmnopqrstuvwxyz
ɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz

Punctuation:
&_?!"'.,
⅋‾¿¡„,˙'

Cas de test

S: The quick brown fox jumps over the lazy dog.
N: 30
Output:
The quick brown fox jumps over
                ˙ƃop ʎzɐl ǝɥʇ 

S: Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque vel libero arcu. Nunc dictum elementum lectus nec aliquet. Donec dolor nunc, sodales at dolor rhoncus, hendrerit scelerisque purus. Pellentesque vel sagittis libero, et rutrum leo. Nullam vulputate enim et massa dictum, vitae venenatis augue lobortis. Fusce sollicitudin ultrices consequat. Vestibulum quis nunc non tortor eleifend facilisis. In at nunc elit. Aliquam pellentesque, lectus quis aliquam posuere, quam lectus sagittis metus, ut auctor sem quam a neque. Integer rhoncus lobortis nisl. Pellentesque mi dui, laoreet in metus quis, mollis accumsan est. Nunc dignissim tortor ac eleifend tempus. Ut ut tellus aliquam, luctus nulla quis, consectetur nunc. Suspendisse viverra molestie condimentum. Curabitur et hendrerit augue.
N: 50
Output:
Lorem ipsum dolor sit amet, consectetur adipiscing
uǝɯǝlǝ ɯnʇɔᴉp ɔunN ˙nɔɹɐ oɹǝqᴉl lǝʌ ǝnbsᴉnQ ˙ʇᴉlǝ 
tum lectus nec aliquet. Donec dolor nunc, sodales 
lǝԀ ˙snɹnd ǝnbsᴉɹǝlǝɔs ʇᴉɹǝɹpuǝɥ 'snɔuoɥɹ ɹolop ʇɐ
lentesque vel sagittis libero, et rutrum leo. Null
sᴉʇɐuǝuǝʌ ǝɐʇᴉʌ 'ɯnʇɔᴉp ɐssɐɯ ʇǝ ɯᴉuǝ ǝʇɐʇndlnʌ ɯɐ
 augue lobortis. Fusce sollicitudin ultrices conse
ɔɐɟ puǝɟᴉǝlǝ ɹoʇɹoʇ uou ɔunu sᴉnb ɯnlnqᴉʇsǝΛ ˙ʇɐnb
ilisis. In at nunc elit. Aliquam pellentesque, lec
ʇǝɯ sᴉʇʇᴉƃɐs snʇɔǝl ɯɐnb 'ǝɹǝnsod ɯɐnbᴉlɐ sᴉnb snʇ
us, ut auctor sem quam a neque. Integer rhoncus lo
snʇǝɯ uᴉ ʇǝǝɹoɐl 'ᴉnp ᴉɯ ǝnbsǝʇuǝllǝԀ ˙lsᴉu sᴉʇɹoq
 quis, mollis accumsan est. Nunc dignissim tortor 
u snʇɔnl 'ɯɐnbᴉlɐ snllǝʇ ʇn ʇ∩ ˙sndɯǝʇ puǝɟᴉǝlǝ ɔɐ
ulla quis, consectetur nunc. Suspendisse viverra m
˙ǝnƃnɐ ʇᴉɹǝɹpuǝɥ ʇǝ ɹnʇᴉqɐɹnƆ ˙ɯnʇuǝɯᴉpuoɔ ǝᴉʇsǝlo

Réponses:


5

Utilitaires Bash + GNU, 204

fold -$1|sed 2~2{s/.\\+/printf\ %$1's "`echo "&"|rev`"/e
y/'`printf %s {A..Z} {a..z}`"&_?!\"'.,/∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Zɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz⅋‾¿¡„,˙'/
}"

N est donné sur la ligne de commande et S est donné via STDIN:

$ echo "The quick brown fox jumps over the lazy dog." | ./boustrophedon.sh 30
The quick brown fox jumps over
                ˙ƃop ʎzɐl ǝɥʇ 
$ 

Explication

  • fold -N divise l'entrée en lignes de longueur N.
  • Le reste du traitement se fait par sed, ligne par ligne:
    • 2~2 correspond à toutes les autres lignes, à partir de la ligne 2
    • s/.+/printf %'N's "`echo "&"|rev`"/e utilise la fonction exec de GNU Sed pour appeler un shell pour inverser la ligne et la remplir à gauche avec jusqu'à N espaces
    • y/ABC.../∀qƆ.../ transformer des personnages

La note ABC...est générée à l'aide d'une extension bash et de printf. Aussi quelques citations de fantaisie pour tous les différents personnages.


Merci @isaacg - Je pensais avoir essayé les doubles backticks, mais je suppose que ça m'a manqué.
Digital Trauma

3

Japt , 182 179 octets

Japt est une version abrégée de Ja vaScri pt . Interprète

Ur'.+".?"pV-1 ,@A++%2?SpV-Xl)+Xw m@"„\xA1⅋,'˙¿∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Z[\\]^‾`ɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz"g(Q+"!&',.?"+65o124 m@Xd)a)bX)||X +R:X+R

Comment ça fonctionne

             // Implicit: U = input string, V = input number, A = 10
Ur           // Take U and replace each group X of:
'.+".?"pV-1  //  at least one char, followed by up to V-1 other chars
             //   literally: RegExp("." + ".?".repeat(V-1))
@            // with: (@ is compiled to (X,Y,Z)=>)
A++%2?       //  If we're on an odd row:
SpV-Xl)+     //   Pad it with spaces, then concatenate it with
Xw m@        //   X reversed, with each character X mapped to:
"..."g       //   The character at position N in the string, where N is:
(Q+"!&',.?"  //    Build a string from a quote mark and these chars,
65o124 m@Xd)a) //   and all chars from A..z.
bX)          //    Return the index of X in this string.
||X          //   or if this number is outside the string, default to the original char.
+R           //   Either way, add a newline.
:X+R         //  Otherwise, return the original row text plus a newline.
             // Implicit: output last expression

Il y a quelques problèmes, mais ils ne devraient pas affecter la validité du programme:

  1. User @ Vɪʜᴀɴ m'a récemment aidé à implémenter des raccourcis Unicode, ou des caractères uniques dans la plage 00A1-00FF qui représentent les séquences de plusieurs caractères couramment utilisées. Le problème avec cela est qu'il remplace actuellement les chaînes internes, donc nous ne pouvons pas utiliser ¡directement dans la chaîne pour l'instant. L'alternative sûre \xA1, est de trois octets de plus.
  2. Il est actuellement impossible de saisir un caractère guillemet double. Cela sera corrigé sous peu.

Il existe peut-être un moyen de raccourcir la chaîne. Les suggestions sont les bienvenues!


Agréable! Je voulais essayer de convertir ma solution en Japt plus tard, mais cela prend le gâteau.
Scott

2

CJam, 152

l~_q/\f{Se]}2/{)26,'Af+_el+"&_?!'.,"`+"∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Zɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz„⅋‾¿¡,˙'"erW%}%N*

Testez-le ici.

Je suppose que je devrais chercher à compresser un peu cette chaîne Unicode ...


La compression de cette chaîne Unicode est difficile - les points de code sont partout. À titre d'expérience, j'ai essayé de «zopfli» l'ensemble de mon entrée (y compris les bits sed) et je suis devenu plus gros. Je regarderai avec intérêt pour voir comment vous y parvenez :)
Digital Trauma

2

Javascript (ES6), 407 400 366 360 353 octets

Je ne compte que les deux premières "lignes" de cet extrait comme le nombre total, car le reste est du code pour l'exécuter.

s=`ABCDEFGHIJKLMNOPQRSTUVWXYZqƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMXZabcdefghijklmnopqrstuvwxyzɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz&_?!"'.,⅋‾¿¡„,˙'`,f=(i,w)=>(i=i.match(RegExp(`.{1,${w}}`,"g")),i.map((c,x)=>x%2?" ".repeat(w-c.length)+[...c].reverse().map(b=>(d=s.indexOf(b),"A"<=b&&"z">=b?s[d+26]:" "==b?b:s[d+8])).join``:c).join`
`)

let input = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque vel libero arcu. Nunc dictum elementum lectus nec aliquet. Donec dolor nunc, sodales at dolor rhoncus, hendrerit scelerisque purus. Pellentesque vel sagittis libero, et rutrum leo. Nullam vulputate enim et massa dictum, vitae venenatis augue lobortis. Fusce sollicitudin ultrices consequat. Vestibulum quis nunc non tortor eleifend facilisis. In at nunc elit. Aliquam pellentesque, lectus quis aliquam posuere, quam lectus sagittis metus, ut auctor sem quam a neque. Integer rhoncus lobortis nisl. Pellentesque mi dui, laoreet in metus quis, mollis accumsan est. Nunc dignissim tortor ac eleifend tempus. Ut ut tellus aliquam, luctus nulla quis, consectetur nunc. Suspendisse viverra molestie condimentum. Curabitur et hendrerit augue.";
console.log(f(input, 50));

Explication

s=`A∀ .. ZZaɐ .. &⅋ ..`,                            //Character translation "map"
f=(i,w)=>                                           //Create a function named "f" that takes an (i)nput string and (w)idth
    (                                               //Implicitly return
        i=i.match(RegExp(`.{1,${w}}`,"g")),         //Cut string into arrays every w-th match of anything
        i.map((c,x)=>                               //Loop through each element in array by (c)ut at inde(x)
            x%2                                     //If the index is odd
                ?" ".repeat(w-c.length)                 //Output spaces for padding
                    +[...c].reverse()                   //Split this cut into each character, and read it backwards
                    .map((b,d)=>(                       //Translate each character
                        d=s.indexOf(b),                 //Save where this character appears in the mapping
                        "A"<=b&&"z">=b                  //If the character is a-zA-Z
                        ?s[d+26]                            //Print the flipped character by looking 26 characters ahead of where this character is found
                        :" "==b                             //Else, if it's a space
                            ?b                              //Output the space
                            :s[d+8]))                   //Else, print the flipped punctuation character (only 8 of these)
                    .join``                         //Join everything back into a continuous string
                :c                                  //Else just output the whole cut
            ).join`                                 
`)                                                  //Finally join each cut by a newline

  • Merci à Dendrobium pour -6 octets!
  • Merci au Closure Compiler pour -34 octets!
  • Merci à ן nɟuɐɯɹɐ ן oɯ pour -7 octets!

1
Vous pouvez réduire tous vos .split("")et vos .join("")à .split``et .join``raser quelques octets. Le .join("\n")peut également être réécrit comme ci-dessus avec une nouvelle ligne littérale au lieu de \n.
Dendrobium

Grands conseils, merci beaucoup!
Scott

1
Vous pouvez supprimer le nouveau mot-clé pour l'expression régulière. Utilisez également exec au lieu de match. Oh oui, utilisez [... c] au lieu de c.split ''.
Mama Fun Roll

@ ן nɟuɐɯɹɐ ן oɯ Nice, merci! Je ne pouvais pas comprendre comment l'utiliser execet le garder court cependant, car il execdoit être bouclé pour obtenir tous les matchs.
Scott

Oh, peu importe à propos d'exec ...
Mama Fun Roll

1

Pyth, 141 octets

FNrZlKczQI%N2X.[" "Q_@KN++GrG1"&_?!\"'.,""ɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Z⅋‾¿¡„,˙'")E@KN

Testé avec un compilateur Pyth en ligne.

Comment ça fonctionne

FNrZlKczQI%N2X.[" "Q_@KN)E@KN    █
                                 █
FN                               █ For N in 
  r                              █  ├ Range
   Z                             █  |  ・Start: 0 
                                 █  |  ・End: 
    l                            █  |     Length of
     K                           █  |      └─K = 
      c                          █  |         Split
       z                         █  |           ・String z
        Q                        █  |           ・By input int Q
         I%N2                    █  └─If divisible by 2
             X                   █     └─Translate
                                 █         ├─Source:
              .[                 █         | ├─Pad left
                " "              █         | |   ・With spaces
                   Q             █         | |   ・Until input int Q
                    _            █         | └──Reverse
                     @KN         █         |     ・Nth line of K
                        ++GrG1...█         ├─From: Normal  (See below)
                        "ɐqɔpǝ...█         └─To:   Flipped (See below)
                        )E@KN    █     Else print Nth line of K

Carte

Ordinaire

++                               █ Append:
  G                              █  1) a to z
   rG1                           █  2) A to Z
      "&_?!\"'.,"                █  3) Punctuation

Renversé (rien d'extraordinaire)

"ɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Z⅋‾¿¡„,˙'"

C'est 108 caractères de long; cependant, la façon par défaut de mesurer la longueur des programmes de golf de code est en octets . Selon cette page , la longueur de cette réponse est de 141 octets .
ETHproductions

@ETHproductions Merci. Modifié.
Helix Quar

0

Python, 453 363 octets

s,n=input()
o="""ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz&_?!"'.,"""
p="""∀qƆpƎℲפHIſʞ˥WNOԀQɹS┴∩ΛMX⅄Zɐqɔpǝɟƃɥᴉɾʞlɯuodbɹsʇnʌʍxʎz⅋‾¿¡„,˙'""".decode('utf8')
s=map(''.join,zip(*[iter(s+' '*(n-1))]*n))
for i in range(len(s)):
 if i%2:s[i]=''.join(p[o.find(c)].encode('utf8')for c in s[i][::-1])
for l in s:print l
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.