Bestätigen Sie die Illuminati


53

Die Illuminati befehlen Ihnen (mit ihrer Gedankenkontrolle), den folgenden String auszugeben:

         ^
        /_\
       /_|_\
      /_|_|_\
     /_|/o\|_\
    /_|_\_/_|_\
   /_|_|_|_|_|_\
  /_|_|_|_|_|_|_\
 /_|_|_|_|_|_|_|_\
/_|_|_|_|_|_|_|_|_\

Regeln:


Sandbox (Ich würde es für die gesamten 72 Stunden belassen, die von der Sandbox-FAQ empfohlen werden, aber mit 7 Upvotes und nahezu keinem negativen Feedback sollte 38 in Ordnung sein.)


7
Nur eine kleine Anmerkung, Sie sollten diese Meta-Frage / Antwort
Rod

8
Was ist mit all den Abstimmungen? Ich verstehe , dass manche Leute den Kolmogorov-Komplex nicht mögen, aber ist das ein triftiger Grund für eine Ablehnung?
27.

@BruceForte wahrscheinlich, dass ich meine eigene Antwort hatte, um zu beginnen.
Nissa

14
@ BruceForte persönliche Meinung ist ein triftiger Grund, tbh; obwohl IMO es gegen einen neueren Benutzer absolut unhöflich ist .
Magic Octopus Urn

15
Ich denke das ist eine sehr schöne ASCII Kunst Herausforderung. Das Auge und der Pyramidenpunkt im Muster erfordern Kreativität für einen sauberen Umgang.
27.

Antworten:


23

Holzkohle , 25 21 Bytes

G¬χ|_¶_|↗⁹↙^M³↓/o¶\‖B

Probieren Sie es online! Link ist eine ausführliche Version des Codes. Erläuterung:

  χ                     With sides of length 10
 ¬                      In the directions down and left
G                       Draw a closed polygon (implicit side)
   |_¶_|                Filled with |_ and _| on alternate lines
        ↗⁹               Draw a line of 9 /s
          ↙^            Draw a ^ and move the cursor down and left
            M³↓         Move down 3 characters
               /o¶\     Print the left half of the eye
                   ‖B  Reflect the canvas keeping the right edge

Da ist es! Fragte mich, wie lange es dauern würde.
Nissa

1
@StephenLeppik Ich war am Telefon :-(
Neil

Warten Sie, ist das der einzige Grund?
Nissa

@StephenLeppik: na ja, das und je nachdem, wie lange ich die Benachrichtigung für einen neuen Hauptbeitrag bemerkt habe, denke ich.
Neil

@DLosc <ist eines der multidirektionalen Elemente - wenn es mit dem MultiprintBefehl verwendet wird, wird der String zweimal gedruckt, einmal rechts oben und einmal rechts unten, aber es kann auch als Abkürzung für ↗↘andere Kontexte verwendet werden.
Neil


10

V , 37 Bytes

9i|_á\|r/òÄó_|
>òC ^4jhR/o\j2hR\_/

Probieren Sie es online!

Hexdump:

00000000: 3969 7c5f 1be1 5c7c 722f f2c4 f35f 7c0a  9i|_..\|r/..._|.
00000010: 3ef2 4320 5e1b 346a 6852 2f6f 5c1b 6a32  >.C ^.4jhR/o\.j2
00000020: 6852 5c5f 2f                             hR\_/

Erläuterung:

9i                              " Insert 9 copies of...
  |_                            "   '|_'
    <esc>                       " Return to normal mode
         á\                     " Append a backslash
           |                    " Move to the first character
            r/                  " Replace it with a forward slash
              ò                 " Recursively...
               Ä                "   Duplicate this line (upwards)
                ó               "   Remove one instance of..
                 _|             "     '_|'
>                               "   Indent this line with one space
 ò                              " End the loop
  C ^                           " Change this line (previously '/_\') to ' ^'
     <esc>                      " Return to normal mode
          4j                    " Move down 4 lines
            h                   " Move one character to the left
             R                  " Write this text over existing characters...
              /o\               "   '/o\'
                 <esc>          " Return to normal mode
                      j         " Move down a line
                       2h       " Move two characters to the left
                         R      " Write this text over existing characters...
                          \_/   " '\_/'

10

SOGL V0.12 , 31 27 25 Bytes

 ^9∫Ƨ_|m└Κ}¹±§"/o¶\_”95žΓ

Probieren Sie es hier aus!

 ^                         push "^"
  9∫      }                do 9 times, pushing counter
    Ƨ_|                      push "_|"
       m                     mold that to the counter
        └Κ                   prepend "/"
           ¹               collect the lines in an array - ["^", "/_", "/_|", ..., "/_|_|_|_|_"]
            ±              reverse each                    ["^", "_/", "|_/", ..., "_|_|_|_|_/"]
             §             reverse as ascii-art:
                            ["         ^",
                             "        /_",
                             "       /_|",
                             ...,
                             "/_|_|_|_|_"]
              "/o¶\_”      push "/o
                                 \_"
                     95ž   insert that at [9; 5]
                        Γ  palindromize horizontally

oder eine 24-Byte-Version mit ¼(Leerzeichen gegen eine Antidiagonale) anstelle von ±§:

 ^9∫Ƨ_|m└Κ}¹¼"/o¶\_”95žΓ

Probieren Sie es hier aus!



8

JavaScript (ES6), 95 bis 92 Byte

f=(n=9,s='')=>n--?f(n,s+' ')+s+`/${n-4?n-3?'_|'.repeat(n):'_|/o\\|':'_|_\\_/_|'}_\\
`:s+`^
`

Oder 91 Bytes mit einer führenden neuen Zeile - was meiner Meinung nach nicht erlaubt ist:

f=(n=9,s=`
`)=>n--?f(n,s+' ')+s+`/${n-4?n-3?'_|'.repeat(n):'_|/o\\|':'_|_\\_/_|'}_\\`:s+`^`

Demo

Formatiert und kommentiert

f = (n = 9, s = '') =>    // n = line counter, s = leading spaces
  n-- ?                   // if we haven't reached the top:
    f(n, s + ' ') +       //   do a recursive call with one more leading space
    s +                   //   append the leading spaces
    `/${                  //   append the left border
      n - 4 ?             //   if this is not the 4th row:
        n - 3 ?           //     if this is not the 3rd row:
          '_|'.repeat(n)  //       append the brick pattern
        :                 //     else (3rd row):
          '_|/o\\|'       //       append the top of the eye
      :                   //   else (4th row):
        '_|_\\_/_|'       //     append the bottom of the eye
    }_\\\n`               //   append the right border + line-feed
  :                       // else:
    s + `^\n`             //   append the top of the pyramid and stop the recursion

Führende Leerzeichen sind erlaubt.
Nissa,

8

C (GCC) , 124 122 120 119 117 115 118 Bytes

-1 Byte dank @xanoetux +3 fehlt die unterste Ebene ...

f(i){for(printf("%*c",i=10,94);--i;printf("\n%*c%s_\\",i,47,i^6?i^5?"_|_|_|_|_|_|_|_|_|"+i*2:"_|_\\_/_|":"_|/o\\|"));}

Probieren Sie es online!


5

Haskell, 110 107 Bytes

"         ^\n"++do z<-[1..9];([z..8]>>" ")++'/':g z++"_\\\n"
g 4="_|/o\\|"
g 5="_|_\\_/_|"
g x=[2..x]>>"_|"

Probieren Sie es online!

Diese 9 Felder am Anfang taten weh.

Wie es funktioniert

"         ^\n"++         -- first line, followed by
do                       -- we use the "do" syntatic sugar for monads,
                         -- here the list monad 
   z<-[1..9]             -- for all 'z' from [1..9] perform the following
                         -- and collect the results in a single list
     ([z..8]>>" ")++'/'  --   make the spaces for the current line and
                         --   the left wall '/'
     g z                 --   call g to make the inner part
     "_\\\n"             --   append '_', '\' and a NL

g 4="_|/o\\|"            -- line 4 and 5 are implemented directly
g 5="_|_\\_/_|"
g x=[2..x]>>"_|"         -- all other lines are some copies of "_|"

Edit: -3 Bytes dank @Laikoni:



3

05AB1E , 47 42 40 Bytes

'/„_|ûûû«η'^0ǝ.∞.C":;<IJK"Çv"/o\\_/"Nèyǝ

Probieren Sie es online!

'/„_|ûûû«                                # Push bottom left tier of pyramid.
         η                               # All prefixes of...
          '^0ǝ                           # Replace the tip.
              .∞.C                       # Mirror, Center.
                  ":;<IJK"Ç              # Push [58,59,60,73,74,75].
                           v"/o\\_/"Nèyǝ # Replace those indexes with the eye.

Dumme Version: „_|3×"_|/o\|".;„_|2×û"_|_\_/_".;


Andere, weniger dumme Version (aber noch schlimmer):

05AB1E , 42 Bytes

•~µÎт•η4¾ǝ•Σ}•4ǝ•3x1•5ǝεS"|_/\^o"sèJ}€.∞.C

Probieren Sie es online!


2

Bubblegum , 48 Bytes

00000000: 5380 8138 2e18 4b3f 3e86 0bce ac01 72e0  S..8..K?>.....r.
00000010: 6c30 0fc6 d1cf 8f01 71e1 cae2 218a e12a  l0......q...!..*
00000020: 6ba0 ea61 7c84 085c 0021 0417 4188 0100  k..a|..\.!..A...

Probieren Sie es online!


2

PHP, 123 + 3 Bytes

+3 Bytes für die seltsame Tab-Zählung. (Es bewegt den Cursor immer noch um 8 Felder in einer beliebigen Konsole!)

for($i=10;--$i;)$r.=str_pad(str_pad("
",$i)."/",20-$i,"_|")."\\";$r[48]=$r[65]="/";$r[50]=$r[63]="\\";$r[49]=o;echo"   ^$r";

Hinweis: Das erste echo"nachfolgende Zeichen ist ein Tabulatorzeichen!

Laufen Sie mit -nroder versuchen Sie es online .

andere Version, gleiche Länge:

for(;$i++<9;)$r.=str_pad(str_pad("
",10-$i)."/",10+$i,"_|")."\\";$r[48]=$r[65]="/";$r[50]=$r[63]="\\";$r[49]=o;echo"    ^$r";

Was ist mit Eclipse? Ich habe es eine Weile nicht benutzt, aber ich erinnere mich, dass die Tabs 4 Leerzeichen waren.
Nissa

@StephenLeppik Eclipse ist ein Editor, keine Shell.
Titus

Es hat noch eine Konsole. Ganz zu schweigen davon, dass der SE-Markdown-Editor und die <pre> -Tag-Schriftart jeweils vier Tabulatoren enthalten
Nissa


2

Ruby, 92 Bytes

10.times{|i|s=' '*(10-i)+(i<1??^:"/#{"_|"*~-i}_\\");i/2==2&&s[9,3]="/o\\_/"[i%2*2,3];puts s}

2

Excel VBA, 104 Bytes

Anonyme VBE-Sofortfensterfunktion, die die Wahrheit bestätigt.

Version A:

?Spc(9)"^":For i=0To 8:[A1]=i:?Spc(8-i)"/_"[If(A1=3,"|/o\|_",If(A1=4,"|_\_/_|_",Rept("|_",A1)))]"\":Next

Version B:

?Spc(9)"^":For i=0To 8:[A1]=i:?Spc(8-i)"/_"IIf(i=3,"|/o\|_",IIf(i=4,"|_\_/_|_",[Rept("|_",A1)]))"\":Next

2

Python 2 , 154 Bytes

l=bytearray
a,b=' _';g=[l(a*9+"^"+a*9)]+[l(a*(8-k)+"/%s\\"%"|".join(b*k+b))for k in range(9)]
g[4][8:11]=l("/o\\")
g[5][8:11]=l("\\_/")
for r in g:print r

Probieren Sie es online!

-3 Bytes Verwendung bytearraydank Rod
-1 Bytes dank Bobrobbob


1

Javascript 90 Bytes (wenn Standardparameter a = 9 erforderlich ist, dann 92 Bytes)

A=(a,x=``)=>a?A(a-1,x+" ")+x+"/".padEnd(a*2,a^5?a^4?"_|":"_|/o\\|":"_|_\\_/")+`\\
`:x+`^
`
console.log(A(9))


Alle überflüssigen Argumente müssen in der Bytesumme enthalten sein, sodass dies 91 Bytes
ergibt

1

Java 8, 156 Bytes

v->"".format("%1$9s^\n%1$8s/a%1$7s/ba%1$6s/bba     /b/o\\|a    /b_\\_/ba   /bbbbba  /bbbbbba /bbbbbbba/bbbbbbbba","").replace("a","_\\\n").replace("b","_|")

Erläuterung:

Probieren Sie es hier aus.

v->                        // Method with empty unused parameter and String return-type
  "".format(               //  Format the following String (`%1$Ns` = N spaces)
      "%1$9s^\n            //            ^
       %1$8s/a             //           /_\
       %1$7s/ba            //          /_|_\
       %1$6s/bba           //         /_|_|_\
            /b/o\\|a       //        /_|/o\|_\
           /b_\\_/ba       //       /_|_\_/_|_\
          /bbbbba          //      /_|_|_|_|_|_\
         /bbbbbba          //     /_|_|_|_|_|_|_\
        /bbbbbbba          //    /_|_|_|_|_|_|_|_\
       /bbbbbbbba","")     //   /_|_|_|_|_|_|_|_|_\
    .replace("a","_\\\n")  //  Replace all "a" with "_\" + new-line
    .replace("b","_|")     //  Replace all "b" with "_|"
                           // End of method (implicit / single-line return-statement)


1

Julia, 152 141 139 130 127 120 113 112 Bytes

q="_|";a+b=" "^a*b;a\b=replace(a,q^3,q*b,1);~n=n<0?9+"^\n":~(n-1)*(8-n+"/$(q^n)_\\\n");print(~8\"/o\\|"\"_\\_/")

Erklärt:

#Define constant q to abbreviate this string
q="_|";

#Redefine the addition operator to compactly provide whitespace 
#where needed
a+b=" "^a*b;

#Redefine the inverse division operator so we can substitute 
#"_|_|_|" with "_|"*b very compactly
a\b=replace(a,q^3,q*b,1);

#Redefine the bitwise not operator to generate pyramid layers
#Defines them recursively, calling itself to generate previous 
#layers before appending its own. 
#The base case generates the tip. 
~n=n<0?9+"^\n":~(n-1)*(8-n+"/$(q^n)_\\\n");

#Print to output
print(

    #Pyramid with 8 body layers
    ~8

    #Then patch in the eye
    \"/o\\|"
    \"_\\_/"
)

1

C # (.NET Core) , 174 153 Bytes

()=>string.Format(@"{1,10}
{0,10}\
{0,9}{2}{3,10}{2}{0,7}|/o\{2}{3,8}\_/_{2}{0,5}{4}  {3}{4} {3}|_{4}{3}|_|_{4}","/_","^",@"|_\
","/_|_",@"|_|_|_|_|_\
")

Probieren Sie es online!

Eine ineffiziente Art, die Pyramide zu bauen, aber interessant, sie durchzuarbeiten.

Danksagung

-21 Bytes dank @someone



0

JavaScript, 117 Bytes

Ich weiß , dass ich keine der Golfsprachen besiege, aber ich kann zumindest meine eigene Lösung nennen.

$=>[...Array(10)].map((e,i)=>' '.repeat(9-i)+(i--?`/${['_|/o\\|','_|_\\_/_|'][i-3]||'_|'.repeat(i)}_\\`:'^')).join`
`

Hier ist eine Demo:

var f = $=>[...Array(10)].map((e,i)=>' '.repeat(9-i)+(i--?`/${['_|/o\\|','_|_\\_/_|'][i-3]||'_|'.repeat(i)}_\\`:'^')).join`
`;
console.log(f());
console.log(f.toString().length);

Erläuterung:

$=>                                       // outer function start
[...Array(10)]                            // create an array to map
.map(…)                                   // map it
    (e,i)=>                               // mapping function start
    ' '.repeat(9-i)                       // spaces for padding
    +(i--?…:'^')                          // use the carat if at the top of the pyramid
        `/${…}_\\`                        // otherwise, make the sides + steps
            ['_|/o\\|','_|_\\_/_|'][i-3]  // use the patterns for the eye, if in the correct rows
            ||'_|'.repeat(i)              // otherwise, make the "bricks" structure
.join`
`                                         // join all the rows into a string (yes this part has a newline in it)

4
Es wird nicht empfohlen, sofort zu antworten und die Leute ihre eigenen Lösungen finden zu lassen.
Okx

0

Javascript, 238 Bytes

Mein allererster Versuch mit Codegolf: D

var f=()=>{let b=x=>' '.repeat(x),g='\\',h='/',i=1,st=[(b(9)+'^').split('')];for(;i<10;i++)st.push((b(9-i)+h+st.map(i=>'_').join('|')+g).split(''));st[4][8]=st[5][10]=h;st[4][9]='o';st[5][8]=st[4][10]=g;return st.map(s=>s.join('')).join('\n');}

document.getElementById("display").innerHTML = f();
console.log(f.toString().length);
<pre id="display">
</pre>


1
Willkommen auf der Seite!
Caird Coinheringaahing

Hardcoding ist definitiv kürzer als das, was Sie hier haben. Sie können dies mit ein paar ES6 Funktionen verkürzen: function`s` statt function('s'), a=>statt ()=>, fill(x)statt map(e=>x), [...s]statt s.split(''), eine Erklärung in die bewegen forInitialisierung usw.
Nissa
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.