बुस्ट्रोफेडन पाठ को उलट दें


19

बाउस्ट्रॉफेडॉन एक प्रकार का द्वि-दिशात्मक पाठ है जहां क्रमिक लाइनें बाएं से दाएं और बाएं से बाएं पढ़ने के बीच वैकल्पिक होती हैं। पढ़ने की दिशा के संबंध में चरित्र दिशा को भी प्रतिबिंबित किया गया था। रिवर्स ब्रॉस्ट्रोफेडन लेखन प्रणालियों में, वर्णों को दर्पण के बजाय 180 घुमाया गया था।

चुनौती

एक प्रोग्राम / फ़ंक्शन लिखें जो पाठ की एक स्ट्रिंग और कई स्तंभों को स्वीकार करता है, और प्रत्यावर्ती रेखाओं के साथ निर्दिष्ट स्तंभों में स्वरूपित स्ट्रिंग को आउटपुट करता है जो उल्टा हो जाता है।

इनपुट

आपके कार्यक्रम को दो तर्क स्वीकार करने चाहिए:

  • एस, प्रारूप करने के लिए पाठ की स्ट्रिंग
  • एन, कॉलम की संख्या

उत्पादन

आपके प्रोग्राम को आउटपुट करना चाहिए S को एन कॉलम में लिपटे हुए 180 डिग्री फ़्लिपिंग लाइनों के साथ।

  • पहली पंक्ति की रीडिंग दिशा हमेशा बाएं से दाएं होती है।
  • लाइन टूटने की जगह के बारे में चिंता न करें, किसी भी चरित्र में लाइनों को विभाजित किया जा सकता है, शब्दों के किसी भी सम्मोहन की आवश्यकता नहीं है।
  • आप मान सकते हैं कि इनपुट स्ट्रिंग में कोई पंक्ति विराम नहीं होगा।

यहां आपके चरित्र को उनके फ़्लिप समकक्षों के साथ समर्थन करना चाहिए:

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

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

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

परीक्षण के मामलों

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

जवाबों:


5

बैश + जीएनयू उपयोगिताओं, 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 कमांड लाइन पर दिया गया है और S को STDIN के माध्यम से दिया गया है:

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

व्याख्या

  • fold -N इनपुट को लंबाई N की रेखाओं में विभाजित करता है।
  • बाकी प्रसंस्करण सेड, लाइन-बाय-लाइन द्वारा किया जाता है:
    • 2~2 हर दूसरी पंक्ति से मेल खाता है, पंक्ति 2 से शुरू होता है
    • s/.+/printf %'N's "`echo "&"|rev`"/e GNU सेड के एक्स्ट्रीम फ़ीचर का उपयोग करके शेल को कॉल करने के लिए लाइन को रिवर्स करने के लिए और N- स्पेस के साथ लेफ्ट-पैड के लिए उपयोग किया जाता है
    • y/ABC.../∀qƆ.../ चरित्रों को बदलना

नोट ABC...एक बैश विस्तार और प्रिंटफ का उपयोग करके उत्पन्न होता है। सभी अलग-अलग पात्रों के लिए कुछ फैंसी उद्धरण भी।


धन्यवाद @isaacg - मुझे लगा कि मैंने डबल बैकटिक्स की कोशिश की है, लेकिन मुझे लगता है कि मैं चूक गया।
डिजिटल ट्रामा

3

जाप , 182 179 बाइट्स

Japt , Ja vaScri pt का छोटा संस्करण है । दुभाषिया

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

यह काम किस प्रकार करता है

             // 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

कुछ समस्याएं हैं, लेकिन उन्हें कार्यक्रम की वैधता को प्रभावित नहीं करना चाहिए:

  1. उपयोगकर्ता @ V Short ने हाल ही में मुझे यूनिकोड शॉर्टकट्स, या 00A1-00FF की श्रेणी में एकल वर्णों को लागू करने में मदद की है जो आमतौर पर उपयोग किए जाने वाले कई-चार क्रमों के लिए खड़े होते हैं। इसके साथ समस्या यह है कि यह वर्तमान में स्ट्रिंग्स के अंदर बदल जाता है, इसलिए हम अभी के लिए सीधे स्ट्रिंग में that का उपयोग नहीं कर सकते हैं। सुरक्षित विकल्प, \xA1तीन बाइट्स लंबा है।
  2. वर्तमान में एक दोहरे-भाव वाले चरित्र को इनपुट करना असंभव है। इसे शीघ्र ही ठीक कर लिया जाएगा।

शायद स्ट्रिंग को छोटा करने का एक तरीका है। सुझावों का स्वागत है!


अच्छा! मैं अपने समाधान को बाद में जाप में बदलने की कोशिश करना चाहता था, लेकिन यह केक लेता है।
स्कॉट

2

सीजेम, 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*

इसका परीक्षण यहां करें।

मुझे लगता है कि मुझे उस यूनिकोड स्ट्रिंग को थोड़ा संकुचित करना चाहिए ...


यह कहते हुए कि यूनिकोड स्ट्रिंग कठिन है - कोड पॉइंट सभी जगह हैं। एक प्रयोग के रूप में, मैंने अपनी पूरी प्रविष्टि (सेड बिट्स सहित) की zopfli'ing की कोशिश की और बड़ा हो गया। मैं यह देखने के लिए दिलचस्पी के साथ देख रहा हूँ कि आप इसे कैसे निपटाते हैं :)
डिजिटल ट्रॉमा

2

जावास्क्रिप्ट (ईएस 6), 407 400 366 360 353 बाइट्स

मैं इस स्निपेट में कुल गिनती के रूप में केवल पहली दो "लाइनें" गिन रहा हूं, क्योंकि बाकी इसे चलाने के लिए कोड है।

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));

व्याख्या

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

  • डेंड्रोबियम -6 बाइट्स के लिए धन्यवाद!
  • -34 बाइट्स के लिए क्लोजर कंपाइलर का धन्यवाद!
  • -7 बाइट्स के लिए-n touɐɯɹɐ ɯ oן का धन्यवाद!

1
लीजिए, आपके कम कर सकते हैं .split("")के और .join("")के लिए .split``और .join``कुछ बाइट्स बंद करने के लिए दाढ़ी। इसके .join("\n")बजाय ऊपर की तरह फिर से लिखा जा सकता है एक शाब्दिक newline के साथ \n
डेंड्रोबियम

महान युक्तियाँ, बहुत बहुत धन्यवाद!
स्कॉट

1
आप regex के लिए नया कीवर्ड निकाल सकते हैं। मैच के बजाय एक्जीक्यूटिव का भी उपयोग करें। अरे हाँ, c.split`` के बजाय [... c] का उपयोग करें।
मामा फन रोल

@, N thankuɐɯɹɐ ן oɯ नीस, धन्यवाद! मैं यह पता नहीं लगा सका कि execइसे कैसे उपयोग किया जाए और इसे कम रखा जाए, क्योंकि execसभी मैचों को प्राप्त करने के लिए ओवर लूप करने की आवश्यकता है।
स्कॉट

ओह, निष्पादन के बारे में कभी नहीं ...
मामा फन रोल

1

पायथ, 141 बाइट्स

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

एक ऑनलाइन पायथ कंपाइलर के साथ परीक्षण किया गया।

यह काम किस प्रकार करता है

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

नक्शा

साधारण

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

फ़्लिप (कुछ भी नहीं फैंसी)

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

यह 108 वर्ण लंबा है; हालाँकि, कोड-गोल्फ कार्यक्रमों की लंबाई को मापने का डिफ़ॉल्ट तरीका बाइट्स में हैइस पृष्ठ के अनुसार , इस उत्तर की लंबाई 141 बाइट्स है
ETHproductions

@ETHproductions धन्यवाद। बदला हुआ।
हेलिक्स क्वार

0

पायथन, 453 363 बाइट्स

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
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.