Zrób sobie przerwę, aby zrobić węża!

23

Nasz klasyczny wąż rozwinął brak równowagi hormonów wzrostu . Co gorsza, jego ogon jest zablokowany! Biorąc pod uwagę dane kierunkowe, jak określono wFigure 1 , napisz program, który określi, gdzie będzie rosnąć.

wasd

Rysunek 1. Wprowadzanie kierunkowe.

Specyfikacje programu

  • Czytaj wprowadzony znak po znaku naSTDIN .
  • Po przeczytaniu znaku wypuść węża doSTDOUT . Podaj pusty wiersz pomiędzy każdym wydrukowaniem węża.
  • Wąż składa się z <>v^głowy. Głowa węża może być dowolny okrągły charakter swojego wyboru, takich jak o, 0, O, lub .
  • Każda kombinacja wasdjest ważna dla danych wejściowych.
  • Twój program nie powinien zakładać, że dane wejściowe mieszczą się w określonej długości.
  • Wąż może nakładać się na siebie, nadpisując <>v^. Zobacz przykłady mechaniki uprawy węża.
  • Końcowe białe znaki są w porządku, ale twój wąż musi wyglądać poprawnie.

Punktacja

To jest . Twój wynik to liczba znaków w twoim programie. Najniższy wynik wygrywa!

Przykładowe węże:

Wkład: ddddssaassdddddww

Wydajność:

>>>>v
    v
  v<<  ☺
  v    ^
  >>>>>^

Wkład: dddsssaaawww

Wydajność:

☺>>v
^  v
^  v
^<<<

Wkład: dddsssdddddasddddwww

Wydajność:

>>>v
   v       ☺
   v       ^
   >>>>v<  ^
       >>>>^

Wkład: dddwwdddssssaaaaaaaaawww

Wydajność:

      >>>v
☺     ^  v
^  >>>^  v
^        v
^<<<<<<<<<

Wkład: ddddssssaawwddddd

Wydajność:

>>>>v
    v
  >>>>>☺
  ^ v
  ^<<

Wkład: dddddssaawwwwddddd

Wydajność:

   >>>>>☺
   ^
>>>^>v
   ^ v
   ^<<

Wkład:

ddddaaaasssssdddddddddddwwwwwaaaasssssdddddddddddwwwwwwwwwwsssssaaaasssssdddddddwwwwwddddssaaaasssddddaaaassssssssssdddwwwwwwwddddswaaaassssddaasssaaaaaaaaaawwwwddddssssaaaaaaaaaaawwwwddddsssssssssaaaa

Wydajność:

                  v
                  v
                  v
                  v
                  v
v<<<<  v<<<<  v<<<<  >>>>v
v      v   ^  v   ^  ^   v
v      v   ^  v   ^  v<<<<
v      v   ^  v   ^  v
v      v   ^  v   ^  v
>>>>>>>>>>>>>>>>>>>>>v<<<<
                     v
                     v
                     v  v<<<<
                     v  v   ^
                     v  v
       >>>>v  >>>>v  v  v
       ^   v  ^   v  v  v<<
       ^   v  ^   v  v  v
       ^   v  ^   v  v  v
       ^<<<v<<<<<<<<<<<<<
           v
           v
           v
           v
       O<<<<
hmatt1
źródło
8
Bardzo dobrze. Ale ... WTH to „kod gofl”?
John Dvorak
2
Pozbyłbym się premii, ponieważ tworzenie własnego węża i ciągu wejściowego jest zbyt proste.
Beta Decay
1
@JanDvorak rotfl my bad.
hmatt1
1
@BetaDecay skaluje samolot. W przykładzie golfa kod zaczął się w lewym górnym rogu c, ale ponieważ d jest wyższy, przesuwa się w dół.
hmatt1
2
@chilemagic Thanks! Jeśli oba są dopuszczalne, prawdopodobnie wyjaśnij to w pytaniu.
Ingo Bürk

Odpowiedzi:

5

Ruby, 207 znaków

b=[];x=y=0;gets.chars{|c|b[y]||=[];b[y][x]={?\n=>->{?0},?w=>->{y>0?y-=1:b=[[]]+b;?^},?a=>->{x>0?x-=1:b.map!{|r|[' ']+r};b[y][1]=?<},?s=>->{y+=1;?v},?d=>->{x+=1;?>}}[c][]};puts b.map{|r|r.map{|c|c||' '}.join}

Nie golfowany:

b=[]  #board
x=y=0 #position
gets.each_char{|c|
  b[y] ||= []
  b[y][x] = {
    "\n" => lambda{0},
    "w"  => lambda{if y>0 then y-=1 else b=[[]]+b; "^"},
    "a"  => lambda{if x>0 then x-=1 else b.map!{|r|[' ']+r}; b[y][1]="<"},
    "s"  => lambda{y+=1; "v"},
    "d"  => lambda{x+=1; ">"}
  }[c].call}
puts b.map{|r|r.map{|c|c||' '}.join}

(lambda dla aodpisuje, ponieważ wiersz, do którego pisze powyższe przypisanie, nie jest już na planszy)

John Dvorak
źródło
11

ECMAScript 6 JavaScript (399 401 431 )

Musi być uruchomiony w przeglądarce obsługującej ECMAScript 6 ze względu na funkcje strzałek.

Oto skrzypce, które zostały zmienione, aby działały w dowolnej (zwykłej) przeglądarce, nie używając funkcji strzałek. textareaZamiast tego drukują również na :

Wersja golfowa

i=prompt(),v=[],c=0,x=[0],y=[0],s='unshift',k='slice',t='sort',h=[0,-1,0,1,0]
while(c<i.length){m='wasd'.indexOf(i[c++]);v[s]('^<v>'[m]);x[s](x[0]+h[m]);y[s](y[0]+h[m+1])}f=(a,b)=>a-b
q=x[k]()[t](f)[0],e=x[k]()[t]((a,b)=>b-a)[0],w=y[k]()[t](f)[0],o=[]
while((i=y.pop())!=null){i-=w;j=x.pop()-q;t=(o[i]||Array(e+1-q).join(" ")).split("");t.splice(j,1,v.pop()||"@");o[i]=t.join("")}alert(o.join("\n"))

Animowany gif:

Jeden z przykładów PO:

wprowadź opis zdjęcia tutaj

Przykład z Stiac Maniac :

wprowadź opis zdjęcia tutaj

Bez golfa

Oto (nieco) nie golfowa wersja z jakiegoś czasu, zanim naprawdę zacząłem grać w golfa:

var input = prompt(),
    values = [],
    c = 0,
    x = [0],
    y = [0],
    s = 'unshift';
while (c < input.length) {
    var mapped = 'wasd'.indexOf(input[c++]);
    values[s]('^<v>'[mapped]);
    x[s](x[0]+[0, -1, 0, 1][mapped]);
    y[s](y[0]+[-1, 0, 1, 0][mapped]);
}

var minX = x.slice().sort(function (a,b){return a-b})[0];
var maxX = x.slice().sort(function (a,b){return b-a})[0];
var minY = y.slice().sort(function (a,b){return a-b})[0];

var output = [];
while((i=y.pop())!=null) {
    i-=minY;
    j=x.pop()-minX;
    t=(output[i]||Array(maxX+1-minX).join(" ")).split("");
    t.splice(j,1,values.pop()||"@");
    output[i]=t.join("");    
}

console.log(output.join("\n"));
Ingo Bürk
źródło
Gify są bardzo fajne. Czy są tworzone automatycznie, według skryptu, który napisałeś?
AndoDaan,
1
Dzięki! Dzięki sile Google właśnie sprawdziłem, jak zrobić prezent z nagrania ekranu w Ubuntu. Po prostu używa rejestratora ekranu i convert. Całkiem proste :)
Ingo Bürk
3
(gif, nie prezent)
Ingo Bürk
8

sed, 71

s/w/\^\x1B[D\x1B[A/g
s/a/<\x1B[2D/g
s/s/v\x1B[B\x1B[D/g
s/d/>/g
s/$/@/

Golfscript, 165 126

' '*"\33[":e{e'D'}:-{[e'C'+'<'--]]}:a{[-+'>']]}:d{[e'B'+'^'-e'A']]}:w{[e'A'+'v'-e'B']]}:s{][\[}:+7{;}*''\~[e'H'e'J']\'@'e'20H'

Takie samo podejście jak w mojej poprzedniej odpowiedzi, ale prawidłowe pozycjonowanie kursora przed i po. Jestem dość dumny z podejścia do pozycjonowania kursora - w zasadzie najpierw uruchamia on węża w odwrotnej kolejności, bez drukowania znaków.

Sneftel
źródło
1
Czy możesz dodać przykładowe połączenie? echo "dddddssaawwwwddddd" | sed -e 's/w/\^\x1B[D\x1B[A/g' -e 's/a/<\x1B[2D/g' -e 's/s/v\x1B[S\x1B[D/g' -e 's/d/>/g' -e 's/$/@/'nie daje mi poprawnego wyniku.
Ingo Bürk
Twoje zapytanie po wykonaniu prawdopodobnie zastępuje część węża. Wklej węża bezpośrednio do stdin zamiast pipingu lub dodaj kilka \ns po, @aby twój monit poszedł gdzie indziej.
Sneftel
1
Może się to nie udać, jeśli wąż wejdzie na górę lub na lewo od planszy.
tomsmeding
@tomsmeding Tak, mógłbym to rozwinąć, aby sobie z tym poradzić. Ale pomijając język, naprawdę uważam, że sekwencje kontrolne ANSI to sposób na krótszy kod.
Sneftel
3

Java - 646

Równie dobrze może być pierwszy!

Założę się, że wszyscy możecie to pokonać.

un (rodzaj) golfa

import java.util.*;
public class Snake{
    public static void main(String[]a) {
        int x,y,minX,minY,maxX,maxY;
        x=y=minX=maxX=minY=maxY=0;
        List<Integer>xs,ys=new ArrayList<Integer>();
        xs=new ArrayList<Integer>();
        List<Character>p=new ArrayList<Character>();
        for(int b=0;b<a[0].length();b++){
            int newX=x,newY=y;
            switch(a[0].charAt(b)){
            case'a':newX--;p.add('<');break;
            case's':newY++;p.add('v');break;
            case'd':newX++;p.add('>');break;
            case'w':newY--;p.add('^');break;
            }
            xs.add(x);ys.add(y);
            x=newX;y=newY;
            if(x<minX){minX=x;}
            if(x>maxX){maxX=x;}
            if(y<minY){minY=y;}
            if(y>maxY){maxY=y;}
        }
        char[][]c=new char[maxY-minY+1][maxX-minX+1];
        for(int i=0;i<xs.size();i++)c[ys.get(i)-minY][xs.get(i)-minX]=p.get(i);
        c[y-minY][x-minX]='@';
        for(char[]k:c){for(char l:k){System.out.print(l);}System.out.println();}
    }
}

Mniejszy -

import java.util.*;class S{public static void main(String[]a){int x,y,o,z,s,u;x=y=o=s=z=u=0;List<Integer>j,t=new ArrayList<Integer>();j=new ArrayList<Integer>();List<Character>p=new ArrayList<Character>();for(int b=0;b<a[0].length();b++){int e=x,r=y;switch(a[0].charAt(b)){case'a':e--;p.add('<');break;case's':r++;p.add('v');break;case'd':e++;p.add('>');break;case'w':r--;p.add('^');break;}j.add(x);t.add(y);x=e;y=r;if(x<o)o=x;if(x>s)s=x;if(y<z)z=y;if(y>u)u=y;}char[][]c=new char[u-z+1][s-o+1];for(int i=0;i<j.size();i++)c[t.get(i)-z][j.get(i)-o]=p.get(i);c[y-z][x-o]='@';for(char[]k:c){for(char l:k){System.out.print(l);}System.out.println();}}}

wejście - dddsssdddwwwwaaaaaaaassassssssssdddddddddddddddd

v<<<<<<<<         
v >>>v  ^         
v    v  ^         
v    v  ^         
v    >>>^         
v                 
v                 
v                 
v                 
v                 
>>>>>>>>>>>>>>>>>@

wejście - dddsssdddddasddddwww

>>>v        
   v       @
   v       ^
   >>>>v<  ^
       >>>>^

mój osobisty faworyt - dwdwdwddaasassdddddwdwdwddsdswawaasassdddddddwdwdwddsdswawaasassddddwwwwwwwssssssdsdddwwwwddaassddaassddddsssdddwdwdwddaasasassddddwwwwssssssssasasaaawdwwdwddwwdddddddwdwdwddsdswawaasassddddddddddwwdwwwwaasssassdsdddddddwdwdwwwwasasssssssssssdwwwwwwwddd

                    v                                          
                    v                                          
                    v                                          
                    v   v<<                                    
   v<<   v<<     v<<v   v                                      
  v<    v< ^<   v< ^v   v<<                        v<<     v<  
 >v    >v   ^  >v   >v  v                          v ^    v<^  
>^>>>>>^>>>>>>>^>>>>^>>>>>>>v    v<v               v ^    v ^  
                            v   v< v       v<<    v< ^    v ^  
                            v  v<  v      v< ^<   v >^    v>^  
                            >>>v   v     >v   ^   >v^     v>>>@
                               >>>>>>>>>>^>>>>>>>>>>>>>>>>v^   
                                  ^v                      v^   
                                >>^v                      v^   
                               >^  v                      v^   
                               ^  v<                      v^   
                              >^ v<                       v^   
                              ^<<<                        >^  
Stretch Maniac
źródło
2

C # 607

namespace System{using B=Text.StringBuilder;class P{static void Main(){var f=new Collections.Generic.List<B>(){new B("O")};int w=1,r=0,c=0;for(Action R=()=>f[r].Append(' ',w-f[r].Length+1);1>0;){var key=Console.ReadKey(1>0).KeyChar;if(key=='w'){f[r][c]='^';if(--r<0)f.Insert(r=0,new B());R();f[r][c]='O';}if(key=='a'){f[r][c]='<';if(--c<0){foreach(var s in f)s.Insert(c=0,' ');w++;}R();f[r][c]='O';}if(key=='s'){f[r][c]='v';if(++r>f.Count-1)f.Add(new B());R();f[r][c]='O';}if(key=='d'){f[r][c]='>';if(++c>w++)foreach(var s in f)s.Append(' ');R();f[r][c]='O';}Console.WriteLine(string.Join("\n",f)+"\n");}}}}

„Ungolfed” z białymi spacjami (nie będzie to zsynchronizowane z wersją golfową):

namespace System
{
    using B = Text.StringBuilder;
    class P
    {
        static void Main()
        {
            var f = new Collections.Generic.List<B>() { new B("O") };
            int w = 1, r = 0, c = 0;
            Action R = () => f[r].Append(' ', w - f[r].Length + 1);
            while (true)
            {
                char key = Console.ReadKey(1>0).KeyChar;
                if (key == 'w')
                {
                    f[r][c] = '^';
                    if (--r < 0) { f.Insert(0, new B()); r = 0; }
                    R();
                    f[r][c] = 'O';
                }
                if (key == 'a')
                {
                    f[r][c] = '<';
                    if (--c < 0)
                    {
                        foreach (var s in f)
                            s.Insert(0, ' ');
                        w++;
                        c = 0;
                    }
                    R();
                    f[r][c] = 'O';
                }
                if (key == 's')
                {
                    f[r][c] = 'v';
                    if (++r > f.Count - 1) f.Add(new B());
                    R();
                    f[r][c] = 'O';
                }
                if (key == 'd')
                {
                    f[r][c] = '>';
                    if (++c > w++)
                    {
                        foreach (var s in f)
                            s.Append(' ');
                    }
                    R();
                    f[r][c] = 'O';
                }

                Console.WriteLine(string.Join("\n", f) + "\n");
            }
        }
    }
}
Kok
źródło
2

Python 3: 259 bajtów

x=y=0
b,p,r={},(0,-1,0,1),range
while 1:
 d='wasd'.index(input());b[(x,y)]='^<v>'[d];x+=p[d];y-=p[~d];b[(x,y)]='☺';l,m=([k[i]for k in b]for i in(0,1))
 for j in r(min(m),max(m)+1):print(''.join(b[(i,j)]if(i,j)in b else' 'for i in r(min(l),max(l)+1)))
 print()

Postanowiłem zapisać węża w dykcie ze współrzędnymi dla klawiszy. Następnie znajdź i iteruj w zakresie wyjściowym, zastępując puste spacje.

x = y = 0
board = {}
while 1:
    d = 'wasd'.index(input())
    board[(x, y)] = '^<v>'[d] # body
    x += (0, -1, 0, 1)[d]
    y -= list(reversed((0, -1, 0, 1)))[d]
    board[(x,y)] = '☺' # head

    xs, ys= ([coord[dim] for coord in board] for dim in(0, 1))
    for j in range(min(ys), max(ys)+1):
        print(''.join(board[(i,j)] if (i,j) in board else ' '
                      for i in range(min(xs), max(xs)+1)))
    print()

PS. Mój pierwszy golf :) Daj mi znać, jeśli moja odpowiedź będzie nieodpowiednia

Gilly
źródło
Używanie Ozamiast oszczędza 2 bajty. to czerwony śledź.
Erik the Outgolfer
@ EʀɪᴋᴛʜᴇGᴏʟғᴇʀ nie był tak naprawdę liczony jako 3 bajty.
Martin Ender,
@MartinEnder Musi być , domyślnym kodowaniem jest UTF-8. Miałem wrażenie, że nie został policzony. Mam wrażenie, że to był przypadek i Gilly musi natychmiast go naprawić.
Erik the Outgolfer
@ EʀɪᴋᴛʜᴇGᴏʟғᴇʀ Cóż, technicznie rzecz biorąc, odpowiadający może używać dowolnego kodowania obsługiwanego przez ich interpretera (i jestem prawie pewien, że strona kodowa zgodna z ASCII zawiera ten znak), ale to nie ma znaczenia. Mówię, że liczba bajtów jest już taka sama jak przy użyciu O, więc nie martwiłbym się tym. Z kodu jasno wynika, że ​​nadal działałby dla każdego innego znaku, ale użycie pozwala wygodnie uruchomić przypadki testowe z wyzwania bez zmian.
Martin Ender
@MartinEnder Python używa UTF-8, o czym świadczy jego zdolność do obsługi ciągów znaków Unicode. Aby włączyć tę funkcję, pierwsza lub druga linia musi być #coding=utf-8. Pamiętaj, że #coding=utf-16to nie działa. Dlatego należy liczyć jako 3.
Erik the Outgolfer
2

Python 2.7 - 274 bajty

x,y,m,d,r=0,0,{},(0,-1,0,1),range
for c in raw_input():b='wasd'.index(c);m[(x,y)]='^<v>'[b];x+=d[b];y-=d[~b];m[(x,y)]='@';l,n=([k[h] for k in m] for h in (0, 1))
for j in range(min(n),max(n)+1):print(''.join(m[(i,j)] if (i,j) in m else ' 'for i in range(min(l),max(l)+1)))

Wersja bez golfa

x,y,matrix,delta = 0,0,{},(0, -1, 0, 1)    
for c in raw_input('Command: '):
    d = 'wasd'.index(c)
    matrix[(x, y)] = '^<v>'[d]
    x += delta[d]
    y -= list(reversed(delta))[d]
    matrix[(x, y)] = '@'    
xs, ys = ([xy[i] for xy in matrix] for i in (0, 1))
for j in range(min(ys), max(ys)+1):
    print(''.join(matrix[(i, j)] if (i, j) in matrix else ' '
                  for i in range(min(xs), max(xs)+1)))
Adriaan Erasmus
źródło
2
Witamy w Programowaniu Puzzle i Code Golf! Zgodnie z zasadami przedstawionymi w naszym centrum pomocy wszystkie rozwiązania problemów powinny poważnie konkurować z zastosowanymi zwycięskimi kryteriami. Na przykład należy wziąć udział w turnieju golfowym.
Dennis
1
Dodałem dla ciebie liczbę bajtów, ale jest tam dość niepotrzebnych miejsc, które możesz chcieć usunąć.
Martin Ender
Dzięki chłopaki, wprowadziłem niezbędne zmiany w moim pierwszym wpisie. Wszelkie dodatkowe porady będą mile widziane.
Adriaan Erasmus,
Naprawdę grałem w golfa .
Erik the Outgolfer
@ EʀɪᴋᴛʜᴇGᴏʟғᴇʀ To po prostu drukuje SyntaxError: invalid syntax.
Dennis
2

05AB1E , 35 34 30 28 bajtów

.•₃º•"<>v^"©‡0ªÐUĀ>sŽO^®XkèΛ

Używa 0 jako głowa węża.

-4 bajty dzięki @Grimy .

Wypróbuj online (brak zestawu testów dla wszystkich przypadków testowych jednocześnie, ponieważ nie ma sposobu na zresetowanie Canvas, więc wyniki będą się nakładać ...).

Wyjaśnienie:

.•₃º•          # Push compressed string "adsw"
     "<>v^"    # Push string "<>v^"
           ©   # Save it in variable `r` (without popping)
              # Transliterate the (implicit) input-string,
               # replacing all "adsw" with "<>v^" respectively
               #  i.e. "ddddssaassdddddww" → ">>>>vv<<vv>>>>>^^"
0ª             # Convert the string to a list of characters, and append a 0 (for the head)
               #  → [">",">",">",">","v","v","<","<","v","v",">",">",">",">",">","^","^","0"]
  Ð            # Triplicate this list of characters
   U           # Pop and store one of the three lists in variable `X`
   Ā           # Trutify each character ("0" remains 0; everything else becomes 1)
    >          # And then increase each integer by 1
               #  → [2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1]
  s            # Swap the two lists on the stack
      ®Xk      # Get the index of each character of variable `X` in variable `r` ("<>v^")
               #  i.e. [">",">",">",">","v","v","<","<","v","v",">",">",">",">",">","^","^","0"]
               #   → [1,1,1,1,2,2,0,0,2,2,1,1,1,1,1,3,3,-1]
   ŽO^   è     # And use those to index into the compressed number 6240
               #  → [2,2,2,2,4,4,6,6,4,4,2,2,2,2,2,0,0,0]
Λ              # Use the Canvas builtin with these three lists

Zobacz moją wskazówkę 05AB1E (sekcje Jak kompresować ciągi znaków, które nie są częścią słownika? I Jak kompresować duże liczby całkowite? ), Aby zrozumieć, dlaczego .•₃º•jest "adsw"i ŽO^jest6240 .

Co do krótkiego wyjaśnienia wbudowanego Canvas'a Λi jego trzech argumentów:

Pierwszy argument: długość (-y): rozmiary linii, które chcemy narysować. Ponieważ musimy pamiętać o nakładaniu się, używamy rozmiaru 2 dla każdej postaci i dodatkowego 1 dla głowy węża.
Drugi argument: string (s): znaki, które chcemy wyświetlić. Jakie są postacie w tym przypadku, wraz z głową węża.
Trzeci argument: kierunek (-y): kierunki, w które należy narysować te linie znaków o danej długości. Ogólnie mamy kierunki, [0,7]które odwzorowują te kierunki:

7   0   1
    
6  X  2
    
5   4   3

Dlatego mamy liczbę całkowitą 6240dla kierunków[,,,] odpowiednio.

Zobacz moją wskazówkę 05AB1E, aby uzyskać bardziej szczegółowe wyjaśnienie dotyczące wbudowanego Canvas Λ.

Kevin Cruijssen
źródło
1
Mogłem coś przeoczyć, ale nie sądzę, żeby było γto potrzebne. To wydaje się działać dobrze.
Grimmy
@Grimy Dzięki, rzeczywiście tak jest; fajne alternatywne podejście z listą 2 i 1 na głowę! Udało mi się zaoszczędzić jeszcze 2 bajty na podstawie twojego programu.
Kevin Cruijssen
Dzięki! Mam obecnie 23 lata , ale jest to zupełnie inne podejście, więc mogę zrobić własną odpowiedź, jeśli nie masz nic przeciwko.
Grimmy
@Grimy To rzeczywiście jest zupełnie inne podejście niż moje, więc zachęcamy do opublikowania go. Rzeczywiście spodziewałem się trochę konwersji Unicode i modulo może sprawić, że będzie to krótsze niż transliteracja, ale jestem całkiem szczery z tego rodzaju magicznymi konwersjami liczb całkowitych / ciągów znaków. :)
Kevin Cruijssen
1

Perl - 394

Nie najkrótszy, ale wyprzedza co najmniej Javascript, C # i Java.

use List::Util qw(min max);sub c{()=$_[0]=~/$_[1]/g}%l=(a,['<',-1,0],d,['>',1,0],w,['^',0,-1],s=>['v',0,1]);($s,$x,$y,$w,$h)=($ARGV[0],0,0,max(c($s,a),c($s,d)),max(c($s,w),c($s,'s')));@s=split'',$s;map$x=min($x,$i+=$l{$_}[1]),@s;$i=0;map$y=min($y,$i+=$l{$_}[2]),@s;$x=abs $x;$y=abs $y;map{$m[$y][$x]=$l{$_}[0];$x+=$l{$_}[1];$y+=$l{$_}[2]}@s;$m[$y][$x]='o';map{map{print$_||' '}@$_;print"\n"}@m 

Niektóre sztuczki:

  • Ostrzeżenia i ścisłe nie są włączone, aby umożliwić używanie słów kluczowych i nie deklarowanie zmiennych przed ich użyciem
  • Cienkie przecinki zamiast grubych przecinków, aby zapisać kilka znaków
  • Brak ustawiania wartości początkowych dla zmiennych, gdy nie jest to konieczne
  • W miarę możliwości pozostawiając średniki
  • Definiowanie tablic i skrótów nie jako odniesień, aby uniknąć konieczności używania ->
  • Zezwalanie na szerokość, wysokość musi być większa niż to konieczne, aby uniknąć konieczności ich dokładnego obliczenia (co wymagałoby dodatkowego kodu)

Rzeczy, które bolą:

  • Nie ma wbudowanego sposobu zliczania liczby znaków w ciągu (i tak mogło być dłużej)
  • Brak wbudowanych funkcji min / max, dlatego trzeba zmarnować 27 znaków, aby zaimportować bibliotekę, która to robi (mniej niż definiowanie własnej)
Mccreenan
źródło
1

C - 273 bajtów - z interaktywnym wejściem!

#define F for(i=w*w
*g,*G,x,i,j,w,W,u;main(w){putch(1);F;j=-~getch();g=G){if(!(x%w&&~-~x%w&&x/w&&x/w^~-w)){W=w+6;G=calloc(W*W,4);F-1;u=i%w+i/w*W-~W*3,i==x?x=u:8,i;)G[u]=g[i--];free(g);w=W;}G[x]="<^X>v"[j%=7];G[x+=1-G[x]%3+W*(!!j-j/2)]=1;F;i;)putch(i--%W?G[i]?G[i]:32:10);}}

Pole jest drukowane za każdym razem, gdy znak jest wprowadzany, i rośnie, gdy głowa węża zbliża się do krawędzi. Nie wiem, jak to jest przenośne - ktoś w Internecie powiedział, że getch () nie działa na platformach innych niż Windows. Trudno powiedzieć, czy ASCII 1 będzie wyglądać jak buźka.

Wersja w golfa jest dość irytująca, ponieważ nie ma sposobu, aby z wdziękiem wyjść z programu. Control-C nie działa dla mnie. Z drugiej strony wersja bez golfa kończy się, jeśli zostanie wprowadzony znak inny niż „w”, „a”, „s” lub „d”.

Tak zwany „nie golfowy”:

#define SMILEYFACE 1
int main()
{
    int o;
    int w = 1;
    int *g = 0, *g2;
    int c, n;
    int x = 0;
    for( putch(SMILEYFACE);c = getch(); ) {
        if(c!='w'&&c!='a'&&c!='s'&&c!='d')
            return 1;
        if(!(x%w) | !(~-~x%w) | !(x/w)  | !(x/w-~-w) ) {
            int wnew = w + 4;
            int off = 2;
            g2 = calloc(wnew*wnew,sizeof(int));
            for(n = w*w; --n; )
                g2[ n%w+off + (n/w+off)*wnew ] = g[n];
            free(g);
            g = g2;
            x = (x/w+off)*wnew + x%w + off;
            w = wnew;
        }
        int i = -~c%7;
        g[x] = "<^X>v"[i];
        int dx = 1-g[x]%3 + w * (!!i-i/2);
        x += dx;
        g[x] = SMILEYFACE;
        for(o = w*w; o; )
            putch(o--%w?g[o]?g[o]:32:10);


    }
    return 0;
}
feersum
źródło
1

05AB1E , 23 bajty

Ç7%DÉ+D"^>>v"ºsè0ªDĀ>rΛ

Wypróbuj online!

Wyjaśnienie:

                      # implicit input (eg: "wasd")
Ç                     # codepoints (eg: [119, 97, 115, 100])
 7%                   # modulo 7 (eg: [0, 6, 3, 2])
   DÉ+                # plus itself modulo 2 (eg: [0, 6, 4, 2])
# This is the list of directions that will be passed to 05AB1E's canvas function, Λ.
# 0 means up, 6 left, 4 right, 2 down.

 "^>>v"º              # "^>>v", horizontally mirrored (namely "^>>vv<<^")
D       sè            # index into this with a copy of the list of directions
          0ª          # append "0"
# This is the list of strings that will be drawn.

D                     # duplicate the list of strings
 Ā                    # truthify (maps letters to 1, 0 stays 0)
  >                   # increment each
# This is the list of lengths to draw.

r                     # reverse the stack because Λ takes arguments in the opposite order
 Λ                    # draw!

Ponury
źródło