Zeichne eine ASCII-O'-Laterne für Halloween

28

Halloween ist fast da, der Feiertag, nach dem sich die meisten Menschen von einer hohlen Zuckerdiät entwöhnen müssen.

Schreiben Sie ein Programm, das eine positive ganze Zahl aufnimmt. Wenn die Ganzzahl kleiner als 31 (1 bis 30) ist, geben Sie diese ASCII-Kunst-Kürbislaterne aus und schauen Sie nach rechts, als würden Sie sich auf Halloween freuen:

 _____I_____
| | | | | | |
| | |^| |^| |
| | | |^| | |
| | |VvVvV| |
|_|_|_|_|_|_|

Ist der Eingang ist 31 (das Datum Oktober Halloween ist), gibt die gleiche ASCII-o'-Laterne, aber nach links schaut:

 _____I_____
| | | | | | |
| |^| |^| | |
| | |^| | | |
| |VvVvV| | |
|_|_|_|_|_|_|

Wenn die Eingabe größer als 31 ist, geben Sie eine aufgeblähte ASCII-o'-Laterne aus, die wahrscheinlich zu viel Süßigkeiten gegessen hat. Er kann sich entweder nach links oder nach rechts wenden, da die Übelkeit desorientierend sein kann. So ausgegeben:

 _____I_____
| | | | | | |
| |o| |o| | |
| | |^| | | |
| |XXXXX| | |
|_|_|_|_|_|_|

oder

 _____I_____
| | | | | | |
| | |o| |o| |
| | | |^| | |
| | |XXXXX| |
|_|_|_|_|_|_|

Was auch immer du bevorzugst. Es kann sogar für verschiedene Zahlen über 31 unterschiedlich sein.

Der kürzeste Code in Bytes gewinnt.

Calvins Hobbys
quelle

Antworten:

8

JavaScript (ES6), 185 142 140 136 Bytes

Jetzt können Sie einen Kürbis twittern!

n=>` _____I_____
0 4 1
02421
0 |^| 1
031
|_|_|_|_|_|_|`.replace(/\d/g,x=>x-2?x-3?x^n>30?"| |":"| | |":n>31?"XXXXX":"VvVvV":n>31?"o":"^")

Wahrscheinlich noch Raum für Verbesserungen ...

ETHproductions
quelle
Dieser x^n>30Trick hatte mich zunächst verwirrt, aber als ich herausfand, was los war, stahl ich ihn schamlos, um meine Antwort zu verbessern. Als Entschädigung gebe ich dir trotzdem eine Gegenstimme.
Neil
8

(Aheui) , 914 Bytes

붕빠뿌빠삮빠싸빠받따싼사주따반따퍄속맣이
숚뽀빠소뚜번범뻐터번선야챠슊산받발따다뿌
분뽀더번투빠뿌삮뿌다뿌쑬섣뽀빠뼈ㅇ뚜범쑬
받발따또싾솒빠쏟싿솓아삲쏠쑧뽀터벋터볼설
뿌뻐뻐뻐선썬뻐퍼섟썫선뻐퍼샧셗뺘쎣뺘뼈선
받따반타파빠빠받따받반타타싾삲빠빠빠빠뿌
숟썭뻐선썭뻐섣썭뻐선썭뻐섣썯터범떠범뻐선
빠싽술빠싽산빠싽삳빠싽숟삮쎨뿌서탸쥬싸셔
쀼이썭솓쀼섣싻이연우섞빠쏠뱐선반노쌹뻐숛
손빠쓞유삯쏢으산뽀쌹쏡야뼈섣싺이셗처솓썱
아솓썲솑쏢삱쏜빠쌄숞뚜범범섩뻐분터뿌뻐튜
번이손쎫ㅇ야샨우쌃이쀼뱔뿌떠뽀투또뿌뽀노
본떠벋뻐떠번떠숃볌쎬볌섩뿌빠뽀펴봄벌뽀뻐
샯이멓삭뭏ㅇㅇ이멓샥뎌뵥뿌븀범이멓삭뭏맣
맣이ㅇ몋섨희ㅇㅇㅇㅇㅇ먛뻐살뽀ㅇ솕멓샮속

Probieren Sie es hier aus! (Bitte kopieren Sie den Code und fügen Sie ihn manuell ein.)

Aheui ist vielleicht nicht zum Golfen da, aber es macht trotzdem Spaß. :)

Ausgänge:

N = 10

 _____I_____ 
| | | | | | |
| | |^| |^| |
| | | |^| | |
| | |VvVvV| |
|_|_|_|_|_|_|

N = 31

 _____I_____ 
| | | | | | |
| |^| |^| | |
| | |^| | | |
| |VvVvV| | |
|_|_|_|_|_|_|

N = 40

 _____I_____ 
| | | | | | |
| |o| |o| | |
| | |^| | | |
| |XXXXX| | |
|_|_|_|_|_|_|
JungHwan min
quelle
4

Gelee , 73 Bytes

“ẋƥḷỊKNṇ&JƝ¡'Ɲṣ,c;|Ṙɗ.hṿ#⁴ɠ³Ṙṅ’b8ị“ I|o^Xv_”
<32ị“o^XV“vX”y¢s13µ¹U31=³¤?Y

Volles Programm
TryItOnline!

Könnte zum Golf dieses mit Hilfe von Bounce möglich sein, ŒḄ.

Wie?

“ẋƥḷỊKNṇ&JƝ¡'Ɲṣ,c;|Ṙɗ.hṿ#⁴ɠ³Ṙṅ’b8ị“ I|o^Xv_” - Link 1, Jack construction
“ẋƥḷỊKNṇ&JƝ¡'Ɲṣ,c;|Ṙɗ.hṿ#⁴ɠ³Ṙṅ’              - a base 250 integer
                               b8            - convert to base 8
                                 ị           - index into
                                  “ I|o^Xv_” - literal " I|o^Xv_"
                                             - makes this, without the line feeds:
                                                _____I_____ 
                                               | | | | | | |
                                               | |o| |o| | |
                                               | | |^| | | |
                                               | |XvXvX| | |
                                               |_|_|_|_|_|_|

<32ị“o^XV“vX”y¢s13µ¹U31=³¤?Y - Main link: n
<32                          - 1 if n is less than 32 else 0
   ị                         - index into
    “o^XV“vX”                - list of strings, ["o^XV","vX"]
             y               - map those characters (o->^ and X->V OR v->X) in string:
              ¢              -    call last link (1) as a nilad
               s13           - split into chunks of length 13
                  µ          - monadic chain separation
                          ?  - ternary if:
                         ¤   -     nilad and links as a nilad
                     31=³    -         31 equals first argument
                   ¹         -     identity (do nothing if true)
                    U        -     upend (reverse each if false)
                           Y - join with line feeds
Jonathan Allan
quelle
3

Rubin, 137 Bytes

Gesichtspunkte verbleiben am und nach dem 31..

->n{puts ' _____I_____',(0..4).map{|i|s=[?|]*7*' _'[i/4]
s[5-n/31*2,5]=' | | o| |o |^| VvVvV_|_|_'[i*5,5];s.tr('ovV','^vVoX'[n/32*3,3])}}

Ungolfed im Testprogramm

f=->n{
  puts ' _____I_____',                                #Draw top of pumpkin
  (0..4).map{|i|                                      #then 5 more lines
    s=[?|]*7*' _'[i/4]                                #of 7 | separated by space or _ .
    s[5-n/31*2,5]=' | | o| |o |^| VvVvV_|_|_'[i*5,5]  #Add a line of face with 'o' eyes and 'VvVvV' mouth.
    s.tr('ovV','^vVoX'[n/32*3,3])                     #Substitute characters as necessary.
  }
}

f[gets.to_i]
Level River St
quelle
3

Kohle , 71 Bytes

NβA‹β³²τA§o^τεA§XVτφA§XvτθF³«P↑⁵|_»↑⁵←I←×_⁵‖O→↙↙←←ε↙←^↖↓ε↓→φθφθφ¿⁼β³¹‖←

Hinweis : Dieser Code funktioniert beim letzten Festschreiben zum Zeitpunkt der Veröffentlichung nicht, da die Zeichenfolgenindizierung fehlerhaft ist. Es sollte jedoch ab dem 25. Oktober in dieser Version funktionieren . Es wird auch erfolgreich in der Version ausgeführt, die derzeit auf Try It Online verfügbar ist .

Erläuterung

Charcoal ist eine Sprache für ASCII-Kunst. Die Ausgabe wird auf eine Leinwand gelegt, die am Ende des Programms gedruckt wird.

Installieren

Eingaben abrufen und Gesichtszeichen berechnen:

Nβ        Input number into beta
A‹β³²τ    Assign beta<32 to tau for easy reuse
A§o^τε    Assign appropriate eye character (selected via indexing into "o^") to epsilon
A§XVτφ    Assign outside and middle mouth character to phi
A§Xvτθ    Assign other mouth character to theta

Zeichne den Kürbis

F³«  »    Do this three times:
P↑⁵       Draw a 5-character line upward (using | by default); don't move the cursor
|_         Draw that string, rightward

Nach dieser Schleife haben wir

| | | 
| | | 
| | | 
| | | 
|_|_|_

Nächster:

↑⁵         Draw a 5-character line upward
←I         Draw the stem leftward
←×_⁵       Draw 5 underscores leftward
‖O→       Reflect the canvas rightward, overlapping in the middle

Ergebnis:

 _____I_____ 
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
|_|_|_|_|_|_|

Zeichne das Gesicht

Wir zeichnen das Gesicht nach rechts und ändern es später, falls erforderlich.

↙↙←←ε      Move to the correct spot and draw the right eye (our right, pumpkin's left)
↙←^        Move to the correct spot and draw the nose
↖↓ε        Move to the correct spot and draw the left eye
↓→φθφθφ    Move to the correct spot and draw the mouth with alternating characters

Ergebnis (zur Eingabe 31):

 _____I_____ 
| | | | | | |
| | |^| |^| |
| | | |^| | |
| | |VvVvV| |
|_|_|_|_|_|_|

Überlege, ob es Halloween ist:

¿⁼β³¹      If beta equals 31:
‖←         Reflect canvas leftward

Endgültige Ausgabe:

 _____I_____ 
| | | | | | |
| |^| |^| | |
| | |^| | | |
| |VvVvV| | |
|_|_|_|_|_|_|
DLosc
quelle
2

Pyth - 84 Bytes

Manuelle Basiskomprimierung.

+dj\Im*5\_2Xjb@_MBsMc5@L"^|_V ve"jC"mËÝ8|0càvll+DzSïë¬Ê"7qQ31"Vve"?>Q31"XXo""Vv^

Test Suite .

Maltysen
quelle
2

PHP, 178 176 171 Bytes

$e="| | ";$b=($n=$argv[1]-31)?" |^":"^| ";$c=$n<1?VvVvV:XXXXX;$a=$n<1?$b:" |o";echo" _____I_____\n$e$e$e|\n| |$a|$a$e\n$e|$b$e|\n| |",$n?" |$c":"$c| ","$e\n|_|_|_|_|_|_|";

könnte 5 Bytes mit physischen Zeilenumbrüchen einsparen. Laufen Sie mit -r.

Titus
quelle
1

V , 97 Bytes

é|6i| Y5PÒ_r $.7|rIGÓ /_
3G3f r^jll.kll.5G3f RVvVvVLá
Àé*ñ30|l2GGkld$PñGñ31|l3GÓÞ/o
5GÓãv/Xñͪ

Probieren Sie es online!

Ich bin enttäuscht darüber, wie lange das gedauert hat. Es ist komplizierter als üblich, da V kaum mit Zahlen umgehen kann. Viele Bytes stammen aus der Erstellung von Hacky-Bedingungen. Ich würde eine ausführliche Erklärung posten, aber es hat lange gedauert, bis ich darauf gekommen bin. Hier ist ein Hexdump:

0000000: e97c 3669 7c20 1b59 3550 d25f 7220 242e  .|6i| .Y5P._r $.
0000010: 377c 7249 47d3 202f 5f0a 3347 3366 2072  7|rIG. /_.3G3f r
0000020: 5e6a 6c6c 2e6b 6c6c 2e35 4733 6620 5256  ^jll.kll.5G3f RV
0000030: 7656 7656 1b4c e10a c0e9 2af1 3330 7c6c  vVvV.L....*.30|l
0000040: 3247 1647 6b6c 6424 50f1 47f1 3331 7c6c  2G.Gkld$P.G.31|l
0000050: 3347 d3de 2f6f 0a35 47d3 e376 2f58 f1cd  3G../o.5G..v/X..
0000060: aa                                       .

Zu Ihrer Information, dies wird sehr langsam ablaufen . Es dauert ungefähr 10 Sekunden. Ich weiß, warum das passiert und suche nach Lösungen.

DJMcMayhem
quelle
1

Pyth, 76 Bytes

+dX*11\_5\IjbmX.<.[14d"| "yqQ31<G3?>Q31"XXo""Vv^"c"
|c| |c
|^
|ababa"bt*7"_|

Probieren Sie es online aus.

Verwendet keine Komprimierung. (Ich habe versucht, einige für eine Version der Gesichtsdatenzeichenfolge zu verwenden, diese hat jedoch dieselbe Länge.)

PurkkaKoodari
quelle
1

Java 7, 237 Bytes

String c(int n){char a=n==31?94:n>31?'o':32,b=n<31?'^':32;return(" _____I_____ \n~~~~~~|\n~|"+a+"|"+b+"|"+a+"|"+b+"~|\n~~|"+(n>31?94:a)+"|"+b+"~~|\n~"+(n<31?"~|VvVvV|":n==31?"|VvVvV~|":"|XXXXX~|")+" |\n|_|_|_|_|_|_|").replace("~","| ");}

Ungolfed & Testcode:

Probieren Sie es hier aus.

class M{
  static String c(int n){
    char a = n == 31
              ? 94
              : n > 31
                 ? 'o'
                 : 32,
         b = n < 31
              ? '^'
              : 32;
    return (" _____I_____ \n~~~~~~|\n~|"+a+"|"+b+"|"+a+"|"+b+"~|\n~~|"
        +(n > 31
           ? 94
           :a)
        +"|"+b+"~~|\n~"
        +(n < 31
           ? "~|VvVvV|"
           : n == 31
              ? "|VvVvV~|"
              : "|XXXXX~|")
        +" |\n|_|_|_|_|_|_|")
      .replace("~", "| ");
  }

  public static void main(String[] a){
    System.out.println(c(12));
    System.out.println();
    System.out.println(c(31));
    System.out.println();
    System.out.println(c(100));
  }
}

Ausgabe:

 _____I_____ 
| | | | | | |
| | |^| |^| |
| | | |^| | |
| | |VvVvV| |
|_|_|_|_|_|_|

 _____I_____ 
| | | | | | |
| |^| |^| | |
| | |^| | | |
| |VvVvV| | |
|_|_|_|_|_|_|

 _____I_____ 
| | | | | | |
| |o| |o| | |
| | |^| | | |
| |XXXXX| | |
|_|_|_|_|_|_|
Kevin Cruijssen
quelle
Ist Ihr Golfcode nicht nur eine Funktion, kein vollständiges Programm?
Angzuril
Die JavaScript-Lösung von ETHproductions ist nur eine Funktion. Ich verstehe nicht, warum dies für Java anders ist
brianush1
1

C ++, 222 204 194 Bytes

-18 Bytes dank Kevin Cruijssen und -10 Bytes für den expliziten oberen Teil

using S=std::string;S f(int n){char L[80],o=2*(n>30),i=-1;while(i++<80)L[i]=47<i&i<53?88:i%2?'|':i==20|i==24|i==36?n<32|i>35?94:'o':(i-o)%14?i-o<55?32:95:10;return" _____I_____ "+S(L+o,L+70+o);}

Ungolfed

#include <string>

using S=std::string;
S f(int n){
 char L[80];
 int o=2*(n>30);
 for (int i=0;i<80;i++){
  L[i]=
   (47<i && i<53) ?
   'X' :
   (
    (i%2) ?
    '|' :
    (
     i==20||i==24||i==36 ?
     (n<32||i>35?'^':'o') :
     ((i-o)%14?(i-o<55?' ':'_'):'\n')
    )
   );
 }
 return " _____I_____ " + S(L+o,L+70+o);
}
Karl Napf
quelle
1
Ich habe vor vielen Jahren nur einmal in C ++ programmiert, kann mich also nicht wirklich an vieles erinnern, aber sind Klammern für ternäre Prüfungen obligatorisch? Wenn nicht, könnten Sie viele davon entfernen. Ist es auch möglich, das &&nach &und ||nach zu ändern |? Kompiliert und läuft using S=std::string;S f(int n){char L[80],o=2*(n>30),i=-1;while(i++<80)L[i]=47<i&i<53?88:i%2?'|':i==20|i==24|i==36?n<32|i>35?94:'o':i-o%14?i-o<55?32:95:10;S t(5,95);return' '+t+'I'+t+' '+S(L+o,L+70+o);}( 202 Bytes )?
Kevin Cruijssen
1
@ KevinCruijssen Ja, Sie haben Recht. Nur die Klammer um i-oist obligatorisch, also 204 Bytes,
Karl Napf
1

PHP, 222 Bytes

for($s=" ".str_pad("I",11,_,2)." \n";$i<5;$i++)$s.=str_pad("",13,$i<4?"| ":"|_")."\n";$p=($a=$argv[1])<31||!($a%2)?2:0;$s=substr_replace($s,$a>31?XXXXX:VvVvV,$p+59,5);$s[$p+31]=$s[$p+35]=($a>31?o:"^");$s[$p+47]="^";echo$s;

Ausgabe

input:29
 _____I_____ 
| | | | | | |
| | |^| |^| |
| | | |^| | |
| | |VvVvV| |
|_|_|_|_|_|_|

input:30
 _____I_____ 
| | | | | | |
| | |^| |^| |
| | | |^| | |
| | |VvVvV| |
|_|_|_|_|_|_|

input:31
 _____I_____ 
| | | | | | |
| |^| |^| | |
| | |^| | | |
| |VvVvV| | |
|_|_|_|_|_|_|

input:32
 _____I_____ 
| | | | | | |
| | |o| |o| |
| | | |^| | |
| | |XXXXX| |
|_|_|_|_|_|_|

input:33
 _____I_____ 
| | | | | | |
| |o| |o| | |
| | |^| | | |
| |XXXXX| | |
|_|_|_|_|_|_|

input:34
 _____I_____ 
| | | | | | |
| | |o| |o| |
| | | |^| | |
| | |XXXXX| |
|_|_|_|_|_|_|

input:35
 _____I_____ 
| | | | | | |
| |o| |o| | |
| | |^| | | |
| |XXXXX| | |
|_|_|_|_|_|_|
Jörg Hülsermann
quelle
1

Groovy Script, 273 265 216 202 198 Bytes

i=args[0]as int
a=i<32?'^| |^':'o| |o'
b=i<32?'VvVvV':'XXXXX'
j=i>30
print" _____I_____\n| | | | | | |\n| |${j?"$a| ":" |$a"}| |\n| | |${j?'^| ':' |^'}| | |\n| |${j?"$b| ":" |$b"}| |\n|_|_|_|_|_|_|"

Ungolfed-Version

i = args[0] as int
a = i < 32 ? '^| |^' : 'o| |o'
b = i < 32 ? 'VvVvV' : 'XXXXX'
j = i > 30
print """ _____I_____
| | | | | | |
| |${j ? "$a| " : " |$a"}| |
| | |${j ? '^| ' : ' |^'}| | |
| |${j ? "$b| " : " |$b"}| |
|_|_|_|_|_|_|"""

Probieren Sie es hier aus

Bearbeiten

Wie Titus erwähnt hat, kann ich mit i < 32statt etwas Größe spareni in 1..31

Bearbeiten 2

Alle möglichen Leerzeichen um Operatoren entfernt ... Am Anfang vergessen

Bearbeiten 3

Die ternären Bedingungen wurden neu geschrieben, um die gespeicherte Variable zu verwenden. Sie wurden durch ;Zeilenumbrüche ersetzt und die explizite Variablendefinition wurde entfernt

Bearbeiten 4

Wie Otávio sagte, kann ich weitere 4 Bytes sparen, wenn ich von | |${j ? ' |^| | ' : ' | |^| '}| |auf umschalte| | |${j ? '^| ' : ' |^'}| | |

Victor A.
quelle
Wie wäre es i < 32statt i in 1..31?
Titus
Sie können die Räume um die Operatoren nicht loswerden?
Fund Monicas Klage
Ja, ich kann ... Völlig vergessen, danke
Victor A.
Da Groovy-Anweisungen entweder durch Zeilenumbrüche oder durch Zeilenumbrüche getrennt werden können ;und beide ein Zeichen lang sind, würde ich die Zeilenumbrüche aus Gründen der Lesbarkeit vorziehen. Und geben Sie mit guten Codierungsgewohnheiten auf, entfernen Sie diese intund def.
Manatwork
In print‚s ersten ternären speichern den Zustand in einer Variablen wie (j=i>30), dann bei der Verwendung nächsten 2 nur jstatt das gleiche von mir wiederholenden i>30Zustand.
Manatwork
1

JavaScript (ES6), 163 bis 125 Byte

f=
n=>` _____I_____
3 5 4
30504
3 |^| 4
3121214
|_|_|_|_|_|_|`.replace(/\d/g,c=>(n>31?`oXX`:`^Vv`)[c]||(c-3^n>30?`| |`:`| | |`))
;
<input type=number oninput=o.textContent=f(this.value)><pre id=o>

Jetzt schamlos den Trick von @ ETHproduction stehlen, um das Gesicht zu positionieren. Kodierung: Ist 0ein Auge 1und 2sind Zähne, 3ist die linke Seite, 4ist die rechte Seite und 5ist der Nasenrücken.

Neil
quelle
0

Ruby, 168 Bytes

->i{s=(Zlib.inflate Base64.decode64 "eJxTiAcBTzDJVaOABCG8OCiGycUhyYWVASGYF48EuRTwGhmHZkgckhzMQBKNzIdibEZGgAA2IwFZA1N4").lines;puts i<31?s[0..5]:i<32?s[6..11]:s[12..17]}

Wahrscheinlich alles andere als optimal. Benötigt die base64und zlibBibliotheken.

Aufruf als Lambda-Funktion.

dkudriavtsev
quelle
0

Python 2, 167 Bytes

i=input()
b='| |';e='^o'[i>31]+b;print'\n'.join(x[::[1,-1][i>30]]for x in[' _____I_____ ','| '*5+b,b+' |'+e+e,b+' | |^| '+b,b+' |'+['VvVvV','X'*5][i>31]+b,'|_'*6+'|'])
TFeld
quelle
-1

C # 6, 223 215 Bytes

int d=int.Parse(args[0]);var x="| | |\n| |";var s=d<31?" |^| |^| |\n| | | |^"+x+" |VvVvV":(d==31?"^| |^"+x+" |^| "+x+"VvVvV| ":"o| |o"+x+" |^| "+x+"XXXXX| ");Write(" _____I_____\n| | | | "+x+s+"| |\n|_|_|_|_|_|_|");

Gesamtes Programm ungolfed:

using static System.Console;
namespace Halloween
{
    public class Program
    {
        public static void Main(string[] args)
        {
            int d = int.Parse(args[0]);
            var x = "| | |\n| |";
            var s = d < 31 ? " |^| |^| |\n| | | |^" + x + " |VvVvV" 
                           : (d == 31 ? "^| |^" + x + " |^| " + x + "VvVvV| " 
                                      : "o| |o" + x + " |^| " + x + "XXXXX| ");
            Write(" _____I_____\n| | | | " + x + s + "| |\n|_|_|_|_|_|_|");
        }
    }
}
IonutC
quelle
2
Dies ist nur ein Code, keine Funktion oder ein Programm. Sie können ihn zu einem kompilieren, Func<int, string>was normalerweise der kürzeste Weg ist, dies zu tun.
TheLethalCoder
1
Ich wette, Sie können einige Bytes einsparen, indem Sie die Bedingungen auf die verschieben, Writeanstatt sie zu deklarieren und zu definieren s.
Titus
2
Und warum \r\nstatt nur \n?
Titus
Niemand hält Sie auf, es besser zu machen
IonutC
3
Sie helfen dir nur!
MrPaulch