जीवन का उत्तर, ब्रह्मांड और ASCII- कला


25

सरल चुनौती: निम्न पाठ को कुछ बाइट्स में आउटपुट करने का प्रयास करें:

       the        answer
      toli      fetheuniv
     ersea     nde     ver
    ything     the     ans
   wer tol     ife     the
  uni  ver           sean
 dev   ery         thin
gth    ean       swer
tolifetheuni    ver
seandeveryth   ing
       the     ans      wer
       tol     ifetheuniver
       sea     ndeverything

मूल ड्राइंग में 332 अक्षर हैं।

नियम

  • कोई इनपुट या अप्रयुक्त इनपुट नहीं।
  • आउटपुट किसी भी उचित प्रारूप में हो सकता है (स्ट्रिंग, स्ट्रिंग की सूची, वर्णों का मैट्रिक्स और इसी तरह)।
  • यदि आप अपनी पसंद के अनुसार ड्राइंग के लिए लोअरकेस के बजाय अपरकेस का उपयोग कर सकते हैं।
  • अनुगामी व्हाट्सएप और न्यूलाइन्स की अनुमति दी।
  • यह , इसलिए प्रत्येक भाषा की जीत के लिए सबसे छोटा कार्यक्रम / कार्य हो सकता है!

टिप्पणियाँ


यह सैंडबॉक्स से आता है ।
चार्ली

1
व्यक्तिगत रूप से, मुझे लगता है कि यह ऑन-टॉपिक है, न कि डूप। मुझे नहीं लगता कि आपको स्पॉइलर उद्धरण की आवश्यकता है, हालांकि।
प्रोग्रामर

1
@Phoenix मुझे नहीं लगता कि यह एक डुबकी है , sogl ने बबलगम को पछाड़ दिया है । इसलिए, संपीड़न ऐसा करने का एक इष्टतम तरीका नहीं है।
प्रोग्रामर

1
सच कहूँ तो, मुझे नहीं पता था कि मेरा फिर से वोट देना बाध्यकारी था। @ प्रोग्रामर 5000 द्वारा पहले ही बताए गए कारणों के लिए, मुझे वास्तव में यह नहीं लगता है कि हम अनजान व्यक्ति हैं । यह दूसरे का एक धोखा हो सकता है - फिर भी पहचान करने के लिए - चुनौती, लेकिन यह नहीं।
अरनुलद

1
@ सबसे अच्छा हिस्सा यह है कि सबसे पहले मैंने पात्रों के 42साथ आकर्षित किया *, और फिर उन्हें पाठ के साथ बदल दिया, जो पूरी तरह से फिट हैं। मुझे वाक्य बनाने के लिए मूल ड्राइंग को संशोधित करने की आवश्यकता नहीं थी। संयोग?
चार्ली

जवाबों:


21

पायथन 3 , 224 220 219 215 211 194 बाइट्स

  • 1 5 बाइट्स के लिए @TFeld का धन्यवाद : if(j%27<1)*jइसके बजाय if j*(j%27<1)और सरलीकृत प्रिंट स्टेटमेंट।
  • 4 बाइट्स के लिए @ लीक नून को धन्यवाद: शून्य 0 और 1 में, शून्य द्वारा पैडिंग की आवश्यकता नहीं थी 7*'0'
  • @ लीक नन ने अपने भयानक गोल्फ कौशल के साथ 17 बाइट्स बचाए (बहुत बहुत धन्यवाद !!!!): मॉड्यूलर इंडेक्सिंग का कमाल
i=j=0
k=int("OHZE5WCKDTW6JYMO1JNROAAJQVAN6F8KEO0SMKJM86XIBMCEH5FXXONZGBAVCN3689DS",36)
while k:j+=1;print(k%2*'theanswertolifetheuniverseandeverything'[i%39]or' ',end='\n'*(j%27<1));i+=k%2;k//=2

इसे ऑनलाइन आज़माएं!

स्पष्टीकरण:

इस द्विआधारी संख्या (नई-लाइन को छोड़कर) को संपीड़ित करने के लिए बेस -36 संपीड़न का उपयोग करता है

111111100011111111000000111
111111000011111100000000011
111110000011111000111110001
111100000011111000111110001
111000100011111000111110001
110001100011111111111000011
100011100011111111100001111
000111100011111110000111111
000000000000111100011111111
000000000000111000111111111
111111100011111000111111000
111111100011111000000000000
111111100011111000000000000

हमारे पास मूल रूप से दो काउंटर हैं iऔर j। एक मुठभेड़ पर 1हम एक अंतरिक्ष प्रिंट करते हैं; यदि 0हम सामने आए हैं तो हम स्ट्रिंग से अगला अक्षर प्रिंट करते हैं और बढ़ाते हैं ijप्रत्येक के लिए बढ़ जाती है 0 or 1। जब भी आवश्यक j%27<1हो तब हम नई-नई लाइनें भी प्रिंट करते हैं।


1
आप को बदलने के द्वारा 1 बाइट बचा सकते हैं if j*(j%27<1):करने के लिएif(j%27<1)*j:
TFeld


2
पूर्णांक अंकगणित के साथ 201 बाइट्स
लीकी नून

2
मॉड्यूलर अनुक्रमण के साथ 200 बाइट्स
लीकी नून


8

पायथन 2 , 235 218 213 बाइट्स

x=bin(int('OC5POO6MZYQNBWY0RP6BKBZCOZL13MIAB6I8YZ5N7LXSZBVKX7GC57AW5631YCJ6XCLC',36))[2:].replace('1',' ')
for c in'theanswertolifetheuniverseandeverything'*4:x=x.replace('0',c,1)
while x:y,x=x[:27],x[27:];print y

इसे ऑनलाइन आज़माएं!

Inw सवाल के संकेत के रूप में पत्र के पदों के लिए एक बेस 36 एन्कोडेड इंट में स्विच किया गया।

एक बार में प्रत्येक वर्ण को प्रतिस्थापित करता है।

       111        111111                              the        answer
      1111      111111111                            toli      fetheuniv
     11111     111     111                          ersea     nde     ver
    111111     111     111                         ything     the     ans
   111 111     111     111                        wer tol     ife     the
  111  111           1111                        uni  ver           sean
 111   111         1111             --->        dev   ery         thin
111    111       1111                          gth    ean       swer
111111111111    111                            tolifetheuni    ver
111111111111   111                             seandeveryth   ing
       111     111      111                           the     ans      wer
       111     111111111111                           tol     ifetheuniver
       111     111111111111                           sea     ndeverything

संपादित करें: ऐसा लगता है कि आधिकारिक तौर पर मेरे पहले बेस 36 का इस्तेमाल किया गया था।


7

बबलगम , 125 बाइट्स

0000000: 45 8f c5 01 03 31 0c 04 ff ae 62 4b 0b 99 02 c7  E....1....bK....
0000010: d8 7d 84 e7 f9 59 30 5e 41 59 4a 84 71 ef e6 3d  .}...Y0^AYJ.q..=
0000020: 4e c1 ea fd b7 42 48 91 66 d6 ae 6e da 89 d3 1c  N....BH.f..n....
0000030: ef 60 ba 97 ae 6e b6 74 2e a5 76 d9 ad ae e4 16  .`...n.t..v.....
0000040: 69 59 08 a6 a6 e8 23 d4 22 af 08 d0 20 7d 17 f0  iY....#."... }..
0000050: 8a 9b 7c 76 c2 61 7b c8 4b 01 41 23 50 24 32 87  ..|v.a{.K.A#P$2.
0000060: f5 98 9e 88 35 24 21 83 ac 50 b2 e0 a2 16 0e 42  ....5$!..P.....B
0000070: bb ba a5 bc ae 6e bd 76 b7 69 d9 f9 07           .....n.v.i...

इसे ऑनलाइन आज़माएं!


आपने इसे कैसे उत्पन्न किया? निकटतम मुझे मिल सकता था 127
संगीतज्ञ 523


मैं zopfli का उपयोग किया था, लेकिन मैं कसम खाता हूँ कि मैं और अतिरिक्त स्थानों के साथ newlines अनुगामी के बिना की कोशिश की .... 127 के तहत नहीं मिल सकता है
Musicman523

6

05AB1E , 83 79 74 बाइट्स

-4 बाइट्स एग्री द आउटग्रॉफ़र के लिए धन्यवाद

बाइट को बचाने के लिए स्ट्रिंग्स की एक सूची को आउटपुट करता है।

•2ÖH₆Ôn₅Ò\ÊÑĆ¸Ý¾*£„ÔûC∞qΘœ™‚¹µ—₃₄fm•vNÈy×vyiðë¾¼’€€Ž»to‚쀀ªÜ€ƒ‰Ö’è}}}J27ô

इसे ऑनलाइन आज़माएं!

व्याख्या

2ÖH₆Ôn₅Ò\ÊÑĆ¸Ý¾*£„ÔûC∞qΘœ™‚¹µ—₃₄fm दशमलव संख्या का आधार 255 प्रतिनिधित्व है:

73869469755353565353431353533323902433339443437469034389033390735363735903735903

जो क्रमशः 1s और 0s के रन को सांकेतिक 1शब्दों में बताता है , यहाँ तक कि सूचकांक के s और असमान indeices को दर्शाता है 0। यह बाइनरी संख्या का मूल्यांकन करता है:

111111100011111111000000111
111111000011111100000000011
111110000011111000111110001
111100000011111000111110001
111000100011111000111110001
110001100011111111111000011
100011100011111111100001111
000111100011111110000111111
000000000000111100011111111
000000000000111000111111111
111111100011111000111111000
111111100011111000000000000
111111100011111000000000000

कोड

•...•                                         Convert from base 255 to decimal
     v                                }       For each digit, do:
      NÈy×                                       is_even(index) repeated that many times
          v                          }           For each digit, do:
           yi                       }               If digit is truthy, then:
             ð                                         Push space
              ë                                     Else:
               ¾¼                                      Get and increment counter, starts at 0
                 ’€€Ž»to‚쀀ªÜ€ƒ‰Ö’                    Push "theanswertolifetheuniverseandeverything"
                                   è                   Get the character at that index
                                       J      Join whole stack
                                        27ô   Split into parts of 27

-4 के "ÔAo îιË3š1ĆRÕ₃FWš{ÓÛÏ.!XµM§&¶ñD°3PŸ{óNι2Ðbмh"253öसाथ बदलें •—."Ôq‚Ā0Ál0j¿«ªžé¨0õ₄7“Ÿ!½ÏiæÆø-δq–Å05q½Yñá+•
एरिक आउटगोल्फर

@EriktheOutgolfer धन्यवाद, मेरा उत्तर अद्यतन और अब मैं अंत में पता है कि इन के लिए कर रहे हैं :)
kalsowerus

अच्छा जवाब :)। आशा है कि आप भाषा सीखते रहेंगे। यदि आपका कोई प्रश्न है तो मुझे बेझिझक बता सकते हैं।
मैजिक ऑक्टोपस Urn

@MagicOctopusUrn बहुत बहुत धन्यवाद! :)
कलसोवरस

6

पायथन 2 , 220 213 212 बाइट्स

-1 स्विचन द्वारा बाइट ()*4के लिए %39से @officialaimm

s=""
w=l=i=0
for g in`int("352G7FS4XC8J2Q2M2HNK7IZI65Z9TVUMHOZ6MR3HY46RQBLWY4PR",36)`[:-1]:
	for j in g*int(g):l+=1;s+=[' ',"theanswertolifetheuniverseandeverything"[w%39]][i%2]+"\n"*(l%27<1);w+=i%2
	i+=1
print s

इसे ऑनलाइन आज़माएं!

यह अन्य पायथन उत्तरों से अलग दृष्टिकोण है। मैं पीएनजी-शैली के एक हेक्स बेस -36 (7 बाइट्स बचाए गए) एन्कोडिंग का उपयोग करता हूं PNG- RLE- स्टाइल एन्कोडिंग छवि (अंकों की एक स्ट्रिंग जो लगातार दोहराया पिक्सल की संख्या को दर्शाता है)।

अंकों की स्ट्रिंग है :

73869469755353565353431353533323902433339443437469034389033390735363735903735903

फिर मैं उन अंकों के माध्यम से पुनरावृत्ति करता हूं और वैकल्पिक रूप से पैलेट से उस संख्या या वर्णों को प्रिंट करता हूं ('theanswer ...)।' जब एक चरित्र के 9 से अधिक दोहराया जाता है, तो मैं बस एक 0 जोड़ूंगा और फिर शेष।


अलग-अलग दृष्टिकोण के लिए +1। आप "theanswertolifetheuniverseandeverything"[w%39] TIO
आधिकारिक

धन्यवाद और नोट किया। मैं इसे 'अब' के साथ ब्रैकेट बूलियन सेटअप के लिए 'या' प्रतिस्थापन के साथ काम करने की कोशिश कर रहा था, लेकिन यह मेरी नई कहानियों को गड़बड़ कर रहा है ...
कोटी जॉनाथन सक्समैन

मुझे नहीं पता था कि PNG ने इस संपीड़न एल्गोरिथम का उपयोग किया है - मुझे लगा कि यह GIF था।
wizzwizz4

अच्छा पकड़ा। यह पीएनजी (न ही जीआईएफ) नहीं था, लेकिन वास्तव में आरएलई था। मैं उत्तर के लिए एक लिंक जोड़ूंगा।
कॉटी जॉनाथन सक्समन

5

SOGL V0.12 , 74 बाइट्स

"ō⅓׀?@C⁶¬IΧΖO‘@øŗč"βΘ⅔Μv∙KΩqψ3╥W≡A;2ļm½±iq╗∆Δ⁶Πqīσ‽ε⁰5τΩ⅜δσΞoΤi┘‽N¹\Λ:‘'    n

यह कोशिश करो!

"...‘              push "the answer to life the universe and everything". because of a bug-not-really-bug, the starting quote is required
     @øŗ           remove spaces
        č          chop it into characters
         "...‘     push a string of spaces and ŗ where ŗ gets replaced with each next characters of the character array
              ' n  split into an array of line length 27

5

मुझे अपने प्रश्न का उत्तर देने की अनुमति दें ...

चारकोल , 140 126 112 बाइट्स

A⟦⟧βF⁶⁸F⁻℅§”c#*U[“⎆Vl¶·δ‴ü"Ip8ξZ{e/⪫¦σMM⪫¢Q⁸ULê←⪫W?—υ⁻$⌀)”ι³⁴«¿﹪鲧”m⌊0Y℅¿№”XJ-⁵η}Z¿8_*<o%!±Ÿ”L⊞Oβω ¿¬﹪L⊞Oυω²⁷⸿

इसे ऑनलाइन आज़माएं!

आपके पास यहां निकटतम वर्बोज़ संस्करण का लिंक है।

स्पष्टीकरण (विवरण के लिए वर्बोज़ संस्करण देखें):

  • )%*(+&(+)''%'%'('%'%&%#%'%'%%%$%-&%%%%+&&%&%)&(.&%*.%%2%'%(%)%'.)%'.स्ट्रिंग (68 बाइट्स, 48 बाइट्स संकुचित) ड्राइंग के RLE एन्कोडिंग का प्रतिनिधित्व है। प्रत्येक चार कोड माइनस 34 रिक्त स्थान की संख्या (यहां तक ​​कि स्थिति) या पाठ वर्णों की संख्या (विषम स्थिति) को लगातार प्रिंट करने के लिए है।
  • एल्गोरिथ्म बस RLE- एन्कोडेड स्ट्रिंग को विघटित करता है और स्ट्रिंग के अगले चार्ट gtheanswertolifetheuniverseandeverythin(39 बाइट्स, 27 बाइट्स संपीड़ित) को लिखता है हर बार एक गैर-व्हाट्सएप चरित्र को लिखने की आवश्यकता होती है। जैसा कि मैं अगले चरित्र को प्राप्त करने के लिए एक सूची की लंबाई की जांच करता हूं और वह सूची एक तत्व से शुरू होती है, स्ट्रिंग का अंतिम चरित्र पहली स्थिति में लिखा गया है।
  • लिखा गया हर 27 अक्षर मैं एक नई पंक्ति सम्मिलित करता हूं।

स्वीकृतियाँ

  • 28 बाइट बचाने और अंत में बबलगम को हराने में सक्षम होने के लिए नील और उनके अद्भुत सुझावों के लिए बहुत धन्यवाद। :-)

1
यदि आप उपयोग करते हैं Assign(Minus(1, c), c);तो आप बस उपयोग कर सकते हैं if (c) { ... } else Print(" ");
नील

वास्तव में यदि आप उपयोग करते हैं for (68)और AtIndex("...", i)तब आप Modulo(i, 2)इसके बजाय उपयोग कर सकते हैं और आपको इसकी आवश्यकता नहीं है c
नील

और यदि आप उपयोग करते हैं if (Not(Modulo(Length(PushOperator(u, w)), 27)))तो आपको इसकी आवश्यकता नहीं है a
नील

ओह, और AtIndexएक स्वचालित करता है Moduloतो Modulo(b, 39)बस हो सकता है b
नील

1
uएक पूर्वनिर्धारित चर है जो सिर्फ एक खाली सरणी है (उपयोग करने से बचाता है A⟦⟧υ)। हर बार जब आप किसी चीज को धक्का देते हैं तो उसकी लंबाई 1 से बढ़ जाती है। यह वेतन वृद्धि के लिए स्पष्ट कार्य से कम है।
नील

5

जावास्क्रिप्ट (ईएस 6), 207 205 203 बाइट्स

कुछ अनुगामी स्थानों के साथ तार की एक सरणी देता है।

let f =

_=>[16515968,33489856,k=58950624,k+16,k-40,31458204,7865230,1966983,462847,233471,117670784,k=134185856,k].map(n=>'heanswertolifetheuniverseandeverythingt '.replace(/./g,(_,i,s)=>s[n>>i&i<27?k++%39:39]))

console.log(f().join('\n'));


4

रेटिना , 183 बाइट्स


7386¶6469¶555353¶465353¶33135353¶23239024¶133394¶034374¶090343¶090333¶735363¶735903¶735903¶theanswertolifetheuniverseandeverything
.*$
$&$&$&$&
(\d)(.)
$1$* $2$*
+s`1([ 1¶]+)(.)
$2$1

इसे ऑनलाइन आज़माएं! स्पष्टीकरण: पहला चरण सेल बिटमैप और पाठ के RLE एन्कोडिंग को जोड़ता है, जो दूसरा चरण फिर सही लंबाई पर डुप्लिकेट करता है, जबकि तीसरा चरण RLE एन्कोडिंग को डीकोड करता है। चौथा चरण तब पाठ को कोशिकाओं में स्थानांतरित करता है।


4

जैली , 83 बाइट्स

“¡eu⁾ṃṣƬİḂṃ½)ṣṾṘƇ@^AṀẆṫ+¢ṗɲ⁾ṭḋZ`⁺×Ṗj½Ṇ-Þḣ2żṿƤc’BCẋ"`“ÆZ⁺ƙ{ÆߥŀŒ1gỤ3Ḍṭṁ ṃjɓ»ṁȯ€⁶s27Y

इसे ऑनलाइन आज़माएं!

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

“XX’BCẋ"`“YY»ṁȯ€⁶s27Y
“XX’                   a large number
    B                  binary
     C                 complement
      ẋ"`              1 becomes [1] and 0 becomes []
             ṁ         reshape
         “YY»             "theanswertolifetheuniverseandeverything"
              ȯ€⁶      replace [] with " "
                 s27   split into chunks of length 27
                    Y  join with newline

3

++ , 1398 बाइट्स जोड़ें

+32
&
&
&
&
&
&
&
+84
&
-12
&
-3
&
-69
&
&
&
&
&
&
&
&
+65
&
+13
&
+5
&
+4
&
-18
&
+13
&
-104
&
+22
&
&
&
&
&
&
+84
&
-5
&
-3
&
-3
&
-73
&
&
&
&
&
&
+70
&
-1
&
+15
&
-12
&
-3
&
+16
&
-7
&
-5
&
+13
&
-108
&
+22
&
&
&
&
&
+69
&
+13
&
+1
&
-14
&
-4
&
-65
&
&
&
&
&
+78
&
-10
&
+1
&
-69
&
&
&
&
&
+86
&
-17
&
+13
&
-104
&
+22
&
&
&
&
+89
&
-5
&
-12
&
+1
&
+5
&
-7
&
-71
&
&
&
&
&
+84
&
-12
&
-3
&
-69
&
&
&
&
&
+65
&
+13
&
+5
&
-105
&
+22
&
&
&
+87
&
-18
&
+13
&
-82
&
+84
&
-5
&
-3
&
-76
&
&
&
&
&
+73
&
-3
&
-1
&
-69
&
&
&
&
&
+84
&
-12
&
-3
&
-91
&
+22
&
&
+85
&
-7
&
-5
&
-73
&
&
+86
&
-17
&
+13
&
-82
&
&
&
&
&
&
&
&
&
&
&
+83
&
-14
&
-4
&
+13
&
-100
&
+22
&
+68
&
+1
&
+17
&
-86
&
&
&
+69
&
+13
&
+7
&
-89
&
&
&
&
&
&
&
&
&
+84
&
-12
&
+1
&
+5
&
-100
&
+93
&
+13
&
-12
&
-72
&
&
&
&
+69
&
-4
&
+13
&
-78
&
&
&
&
&
&
&
+83
&
+4
&
-18
&
+13
&
-104
&
+106
&
-5
&
-3
&
-3
&
-3
&
-1
&
+15
&
-12
&
-3
&
+16
&
-7
&
-5
&
-73
&
&
&
&
+86
&
-17
&
+13
&
-104
&
+105
&
-14
&
-4
&
+13
&
-10
&
+1
&
+17
&
-17
&
+13
&
+7
&
-5
&
-12
&
-72
&
&
&
+73
&
+5
&
-7
&
-93
&
+22
&
&
&
&
&
&
&
+84
&
-12
&
-3
&
-69
&
&
&
&
&
+65
&
+13
&
+5
&
-83
&
&
&
&
&
&
+87
&
-18
&
+13
&
-104
&
+22
&
&
&
&
&
&
&
+84
&
-5
&
-3
&
-76
&
&
&
&
&
+73
&
-3
&
-1
&
+15
&
-12
&
-3
&
+16
&
-7
&
-5
&
+13
&
-17
&
+13
&
-104
&
+22
&
&
&
&
&
&
&
+83
&
-14
&
-4
&
-65
&
&
&
&
&
+78
&
-10
&
+1
&
+17
&
-17
&
+13
&
+7
&
-5
&
-12
&
+1
&
+5
&
-7
&
P

इसे ऑनलाइन आज़माएं!

ऐसा लगता है कि यह सबसे छोटा तरीका है (कम से कम Add ++ में)


3

विम, 239 कीस्ट्रोक्स

:h4<CR>3hy5bZZitheanswerto<Esc>p:%s/ \|,//g<CR>ye3P
lqqi<CR><Esc>qqw3li <Esc>lq3@wbhr<CR>16l@q@w3-@w6l@ql@w9l@qll3@whr<CR>3l9@w4l@q 2@w4l@q2@w4l@q9l2@wlr<CR>9l@w4klr<CR>4whr<CR>jj
el<C-v>3k"aD0jji <Esc>qqdiwukPi <Esc>q5@qwy04j$"ap6+<C-v>GPp3kw3i <Esc>2@q4kbXj2@qywh<C-v>4jp2je<C-v>jj4A <Esc>8j5i <Esc>b<C-v>jj2I <Esc>

लाइनब्रीक्स को "पठनीयता" के लिए जोड़ा गया

व्याख्या

पहली पंक्ति life, the universe and everythingएक सहायता पृष्ठ से निकलती है, जो एक बाइट होती है जो इसे टाइप करने से कम होती है। यह तो इस में बदल जाता है:

theanswertolifetheuniverseandeverythingtheanswertolifetheuniverseandeverythingtheanswertolifetheuniverseandeverythingtheanswertolifetheuniverseandeverything

दूसरी पंक्ति स्ट्रिंग को ऊपर तोड़ती है:

the answer
toli fetheuniv
ersea nde ver
ything the ans
wer tol ife the
uni ver sean
dev ery thin
gth ean swer
tolifetheuni ver
seandeveryth ing
the ans wer
tol ifetheuniver
sea ndeverything

और फिर अंतिम पंक्ति इसे बनाने के लिए प्रेरित करती है:

       the        answer
      toli      fetheuniv
     ersea     nde     ver
    ything     the     ans
   wer tol     ife     the
  uni  ver           sean
 dev   ery         thin
gth    ean       swer
tolifetheuni    ver
seandeveryth   ing
       the     ans      wer
       tol     ifetheuniver
       sea     ndeverything



2

जावास्क्रिप्ट, 215 बाइट्स

Guest44851 पर आधारित समाधान

$=>'a21xb0k9qf30155yiv016ewp3018lkhz0ohfdb077or302cl5b0mgzr0b8hz028ghs7028gi67028gi67'.split(p=0).map(x=>parseInt(x,36).toString(2).slice(1).replace(/./g,x=>" theanswertolifetheuniverseandeverything"[+x&&1+p++%39]))

2

रूबी , 216 बाइट्स

o=i=1
puts"6iffnqxq0opdbco5e3f1zk5d7eezo2j6zwly9z5yykqsc1hl5svaof".to_i(36).to_s(17).chars.map{|c|
o=!o
c.to_i(17).times.map{o ? (i+=1)&&"ngtheanswertolifetheuniverseandeverythi"[i%39]:" "}.join
}.join.scan /.{1,27}/

इसे ऑनलाइन आज़माएं!

व्याख्या पायथन समाधानों के समान है, लेकिन मैंने बेस 36 में बदलने से पहले रन लेंथ एन्कोडिंग का उपयोग किया। इसलिए डेटा स्ट्रिंग 68 के बजाय केवल 54 वर्ण है।

लेकिन यह अभी भी सभी पर समाप्त हो गया है, उम्मीद है कि इसे और आगे बढ़ाया जा सकता है।



2

सी (जीसीसी) , 220 219 217 213 210 बाइट्स

सीटिंग के लिए -1 बाइट धन्यवाद

-3 बाइट्स जेरी जेरेमिया के लिए धन्यवाद

q,i,j,t;main(c){for(;c="HDIG@GEGJ@FFFDFD@EGFDFD@DDBDFDFD@CDCDLE@BDDDJE@ADEDHE@AMED@AMDD@HDFDGD@HDFM@HDFM"[t++];)for(c%=64,j=c?q=!q,c:2;--j;)putchar(c?q?32:"theanswertolifetheuniverseandeverything"[i++%39]:10);}

इसे ऑनलाइन आज़माएं!


एक कार्य केवल आधा कार्यक्रम है - बस 214 बाइट्स के
जेरी जेरेमिया

@ जैरीजेरमैया बहुत सच्चा; अच्छा पकड़ा! इससे एक और बाइट शेव भी कर सकते थे।
गैस्ट्रोपनर

1

जावास्क्रिप्ट, 265 237 219 बाइट्स

(i=0)=>'jwq80,13ntvk,26p62g,25g7w8,239k3c,zg4xc,7rpbk,1e9dc,b8mw,5mbc,4f9reg,4f9r0g,4f9r0g'.split`,`.map(b=>parseInt(b,36).toString(2).slice(1).replace(/./g,c=>'  theanswertolifetheuniverseandeverything'[+c||2+i++%39]))

कुछ @ बाइट के लिए धन्यवाद बाइट्स।

JSFiddle


.substr -> .llice (1) कुछ बाइट्स
बचाएं

"आउटपुट स्ट्रिंग की सूची में हो सकता है" इसलिए join
tsh

@tsh। धन्यवाद। । ।

1

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

इसमें बहुत से बाइट्स शामिल थे जो मुझे TIO में दिखाने के लिए नहीं मिल सकते थे, इसलिए यहां एक हेक्सडंप है:

00000000: 7558 6848 477c 2a64 6548 622c 5658 434d  uXhHG|*deHb,VXCM
00000010: 2290 8d8d 817e 7e7b 7875 7572 6663 5753  "....~~{xuurfcWS
00000020: 504d 4946 4343 3f3c 3939 3633 302d 2d2a  PMIFCC?<99630--*
00000030: 2721 211e 1b16 160d 0909 0300 225d 545d  '!!........."]T]
00000040: 3133 6a43 2202 1232 a464 b09d 7303 4244  13jC"..2.d..s.BD
00000050: 9386 74d2 e954 b89e e722 3132 2a34 2e22  ..t..T..."12*4."
00000060: 6179 1aa6 55ad c176 932b 6088 d5c5 556c  ay..U..v.+`...Ul
00000070: e4f4 5575 12a0 e7fb 1f                   ..Uu.....

इसे ऑनलाइन आज़माएं!

आप इसमें कॉल जोड़ सकते हैं wcया कर सकते हैंxxd बाइट लंबाई या hexdump मैं ऊपर का उत्पादन किया देखने के लिए बैश लिपि में।

दिलचस्प बात यह है कि यह कार्यक्रम पर्थ में एक मामूली बग (?) को प्रदर्शित करता है। किसी भी कैरिज रिटर्न बाइट्स (0x0d) को स्ट्रिंग लिटरल्स में न्यूलाइन बाइट्स (0x0a) के रूप में पढ़ा जाता है। यह मुझे 6 बाइट्स जोड़ने के लिए मजबूर करता है:X ... ]T]13 गलत दस को तेरह के साथ बदलने के लिए।

अन्यथा इस कोड के पीछे का विचार काफी सरल था: प्रत्येक स्थिति को रिकॉर्ड करें जहां व्हाट्सएप का एक रन होता है। फिर, उन सभी सूचकांकों को उस रन में रिक्त स्थान की संख्या के साथ जोड़ दें। फिर, वाक्यांश को चार बार दोहराकर मूल स्ट्रिंग को फिर से बनाएं, फिर सही स्थानों में डालें। यदि दर्ज किए गए रिक्त स्थान की संख्या शून्य थी, इसके बजाय एक नई रेखा सम्मिलित की जाती है।


1

जावा (ओपनजेडके 8) , 258 252 251 बाइट्स

z->{int i=0,x,j,N[]={16515968,33489856,x=58950624,x+16,x-40,31458204,7865230,1966983,462847,233471,117670784,x=134185856,x};for(int n:N)for(j=32;j-->0;n/=2)System.out.print(n%2<1?j<1?"\n":" ":"theanswertolifetheuniverseandeverything".charAt(i++%39));}

इसे ऑनलाइन आज़माएं!

यह एक बहुत अच्छा कार्यान्वयन है। पहले एक मुखौटा, मुद्रित पात्रों के लिए, फिर पाठ पर एक रोल जब तक किया।

  • कार्लोस अलेजो की बदौलत 6 बाइट बच गईं!

आप के साथ कुछ बाइट्स बचा सकते हैं int[]{16515968,33489856,x=58950624,x+16,x-40,31458204,7865230,1966983,462847,233471,117670784,x=134185856,x}
चार्ली

0

जावास्क्रिप्ट, अनुमानित ड्राइंग। 319 बाइट्स

s=32
t="theanswertolifetheuniverseandeverything"
j=0
o=""
b=document.createElement('canvas'),c=b.getContext('2d')
b.width=b.height=s
c.font="25px Verdana"
c.fillText('42',0,20)
m=c.getImageData(0,0,s,s)
i=0
while(i<m.data.length) {
 d=m.data[i+3]
 o+=d?t[j%t.length]:" "
 if(d)j++
 i+=4
}
o.match(/.{1,32}/g).join("\n")

^ इसके लायक क्या है, वास्तव में बहुत ज्यादा नहीं है, लेकिन इससे पहले कि मैं असफल कोड को हटा दूं।

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