Сделай перерыв, чтобы сделать змею!

23

Наша классическая змея разработала дисбаланс гормонов роста . Что еще хуже, его хвост замерз на месте! С учетом направленного ввода, как указано в Figure 1, напишите программу, чтобы определить, где он будет расти.

WASD

Рисунок 1. Направленный вход.

Спецификации программы

  • Читайте ввод за символом на STDIN.
  • Прочитав символ, выведите змею в STDOUT. Пожалуйста, включайте пустую строку между каждым разом, когда вы печатаете змею.
  • Змея состоит из <>v^головы. Голова змеи может быть любой круглый характер вашего выбора, такие как o, 0, Oили .
  • Любая комбинация wasdдействительна для ввода.
  • Ваша программа не должна предполагать, что ввод находится в пределах определенной длины.
  • Змея может навалиться на себя, перезаписывая <>v^. Смотрите примеры для механики выращивания змей.
  • Задний пробел в порядке, но ваша змея должна выглядеть правильно.

счет

Это . Ваша оценка - это количество символов в вашей программе. Самый низкий балл побеждает!

Пример змей:

Входные данные: ddddssaassdddddww

Выход:

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

Входные данные: dddsssaaawww

Выход:

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

Входные данные: dddsssdddddasddddwww

Выход:

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

Входные данные: dddwwdddssssaaaaaaaaawww

Выход:

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

Входные данные: ddddssssaawwddddd

Выход:

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

Входные данные: dddddssaawwwwddddd

Выход:

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

Входные данные:

ddddaaaasssssdddddddddddwwwwwaaaasssssdddddddddddwwwwwwwwwwsssssaaaasssssdddddddwwwwwddddssaaaasssddddaaaassssssssssdddwwwwwwwddddswaaaassssddaasssaaaaaaaaaawwwwddddssssaaaaaaaaaaawwwwddddsssssssssaaaa

Выход:

                  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
источник
8
Очень хорошо. Но ... WTH это "код gofl"?
Джон Дворак
2
Я бы избавился от бонуса, так как слишком легко создать свою собственную змею и строку ввода.
бета-распад
1
@JanDvorak Rotfl мой плохой.
hmatt1
1
@ BetaDecay весы самолета. В примере кода гольфа он начинался в верхнем левом углу буквы c, но, поскольку d выше, он опускается вниз.
hmatt1
2
@chilemagic Спасибо! Если оба приемлемы, вы, вероятно, должны уточнить это в вопросе.
Инго Бюрк

Ответы:

5

Рубин, 207 символов

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}

Ungolfed:

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}

(лямбда для aобратной записи, потому что строка, в которую записывается указанное выше назначение, больше не находится на доске)

Джон Дворжак
источник
11

ECMAScript 6 Javascript (399 401 431 )

Должен запускаться в браузере, поддерживающем ECMAScript 6, из-за функций стрелок.

Вот скрипки, которые были изменены для запуска в любом (обычном) браузере, не используя функции стрелок. Они также печатают textareaвместо:

Гольф версия

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

Анимированный GIF:

Один из примеров ОП:

введите описание изображения здесь

Пример из Stretch Maniac :

введите описание изображения здесь

Ungolfed

Вот (слегка) ungolfed версия от когда - то прежде , чем я начал действительно играть в гольф вниз:

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"));
Инго Бюрк
источник
Гифки очень классные Они сделаны автоматически по написанному вами сценарию?
AndoDaan
1
Благодарность! С помощью Google я только что посмотрел, как сделать подарок из записи экрана в Ubuntu. Он просто использует экран записи и convert. Довольно просто :)
Ingo Bürk
3
(GIF, не подарок)
Инго Бюрк
8

седькая, 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'

Тот же подход, что и в моем предыдущем ответе, но правильное позиционирование курсора до и после. Я очень горжусь подходом к позиционированию курсора - в основном, он сначала запускает змею в обратном порядке, без распечатки символов

Sneftel
источник
1
Можете ли вы добавить пример вызова? 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/$/@/'не дает правильный вывод для меня.
Инго Бюрк
Ваша подсказка после выполнения, вероятно, перезаписывает часть змеи. Вставьте змею прямо в стандартный ввод вместо того, чтобы пипеть, или добавьте несколько \nсекунд после того, как @ваш запрос переместится в другое место.
Sneftel
1
Это может потерпеть неудачу, если змея поднимается или покидает доску.
Томсминг
@tomsmeding Да, я мог бы расширить это, чтобы справиться с этим. Несмотря на язык, я действительно считаю, что последовательности управления ANSI - это путь для более короткого кода.
Sneftel
3

Ява - 646

Может быть и первым!

Бьюсь об заклад, вы все можете победить это.

Un (вроде) гольф

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

Меньше -

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

input - dddsssdddwwwwaaaaaaaassssssssssddddddddddddddddd

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

ввод - dddsssdddddasddddwww

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

мой личный фаворит - 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^   
                              ^<<<                        >^  
Стрейч маньяк
источник
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» с пробелами (это не будет синхронизировано с версией для гольфа):

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");
            }
        }
    }
}
боб
источник
2

Python 3: 259 байт

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

Я решил хранить змею в диктовке с координатами для ключей. Затем найдите и переберите выходной диапазон, заменив пробелы.

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. Мой первый гольф :) Дайте мне знать, если мой ответ неуместен

Джилли
источник
Использование Oвместо экономит 2 байта. красная сельдь
Эрик Outgolfer
@ EʀɪᴋᴛʜᴇGᴏʟғᴇʀ фактически не считается 3 байтами.
Мартин Эндер
@MartinEnder Должно быть , кодировка по умолчанию - UTF-8. У меня было чувство, что это не считается. У меня такое ощущение, что это было случайно и должно быть немедленно исправлено Джилли.
Эрик Outgolfer
@ EʀɪᴋᴛʜᴇGᴏʟғᴇʀ Ну, технически, ответчик может свободно использовать любую кодировку, поддерживаемую его интерпретатором (и я почти уверен, что ASCII-совместимая кодовая страница содержит этот символ), но это не относится к делу. Я говорю, что количество байтов уже такое же, как и при использовании O, поэтому я не стал бы беспокоиться об этом. Из кода видно, что он по-прежнему будет работать для любого другого символа, но использование позволяет удобно запускать тестовые сценарии из задачи без изменений.
Мартин Эндер
@MartinEnder Python использует UTF-8, что подтверждается его способностью поддерживать строки Unicode. Чтобы включить эту функцию, первая или вторая строка должна быть #coding=utf-8. Обратите внимание, что #coding=utf-16не работает. Следовательно должен быть посчитан как 3.
Эрик Outgolfer
2

Python 2,7 - 274 байта

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

Неуправляемая версия

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)))
Адриан Эразм
источник
2
Добро пожаловать в Программирование Пазлов и Code Golf! Согласно правилам, изложенным в нашем справочном центре , все решения проблем должны стать серьезным претендентом на критерии победы в использовании. Например, для участия в соревновании по коду необходимо пройти игру в гольф.
Деннис
1
Я добавил для вас количество байтов, но там довольно много ненужных пробелов, которые вы, возможно, захотите удалить.
Мартин Эндер
Спасибо, ребята, я внес необходимые изменения в мою первую запись. Любые дополнительные советы будут с благодарностью.
Адриан Эразмус
@ EʀɪᴋᴛʜᴇGᴏʟғᴇʀ Это просто печатает SyntaxError: invalid syntax.
Деннис
2

05AB1E , 35 34 30 28 байт

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

Использует в 0качестве головы змеи.

-4 байта благодаря @Grimy .

Попробуйте онлайн (нет набора тестов для всех тестовых случаев одновременно, потому что нет способа сбросить Canvas, поэтому выходные данные будут перекрываться ..).

Объяснение:

.•₃º•          # 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

См. Этот мой совет 05AB1E (разделы Как сжимать строки, не являющиеся частью словаря? И Как сжимать большие целые числа? ), Чтобы понять, почему .•₃º•есть "adsw"и ŽO^есть 6240.

Что касается краткого объяснения встроенного Canvas Λи его трех аргументов:

Первый аргумент: длина (с): размеры линий, которые мы хотим нарисовать. Так как мы должны помнить о перекрытии, мы используем размер 2 для каждого персонажа и дополнительный 1 для головы змеи.
Второй аргумент: строка (и): символы, которые мы хотим отобразить. Которые являются персонажами в этом случае, дополнены главными персонажами змеи.
Третий аргумент: direction (s): направления, в которых должны быть нарисованы эти строки символов заданной длины. В общем, у нас есть направления, [0,7]которые отображаются на эти направления:

7   0   1
    
6  X  2
    
5   4   3

6240[,,,]

Смотрите этот 05AB1E мой совет для более подробного объяснения встроенного Canvas Λ.

Кевин Круйссен
источник
1
Возможно, я что-то пропустил, но я не думаю, что это γвообще нужно. Это , кажется, работает просто отлично.
Grimmy
@ Грими Спасибо, это действительно так; хороший альтернативный подход со списком 2s и 1 для головы! И я смог сохранить еще 2 байта на основе вашей программы.
Кевин Круйссен
Благодарность! Сейчас мне 23 года , но это совершенно другой подход, поэтому я могу дать ему собственный ответ, если вы согласны.
Grimmy
@Grimy Это действительно совершенно другой подход, чем мой, поэтому не стесняйтесь размещать его. Я действительно ожидал какого-то преобразования в юникоде, и по модулю это может быть короче, чем транслитерация, но я, честно говоря, очень плохо отношусь к таким магическим преобразованиям целых чисел / строк. :)
Кевин Круйссен
1

Perl - 394

Не самое короткое, но оно лучше, чем Javascript, C # и 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 

Некоторые хитрости:

  • Предупреждения и строгие не включены, чтобы разрешить использование голых слов и не объявлять переменные перед использованием
  • Тонкие запятые вместо толстых запятых, чтобы сохранить несколько символов
  • Не устанавливать начальные значения для переменных, когда это не нужно
  • Оставляя точки с запятой, когда это возможно
  • Определение массивов и хешей не в качестве ссылок, чтобы избежать необходимости использовать ->
  • Допуская, чтобы ширина и высота были больше, чем необходимо, чтобы избежать необходимости их точного вычисления (что потребовало бы дополнительного кода)

Вещи, которые причиняют боль:

  • Нет встроенного способа подсчета количества символов в строке (возможно, в любом случае было бы больше)
  • Нет встроенных функций min / max, поэтому нужно тратить 27 символов на импорт библиотеки, которая это делает (меньше, чем наша собственная)
mcreenan
источник
1

C - 273 байта - с интерактивным вводом!

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

Поле печатается каждый раз, когда вводится символ, и увеличивается, если голова змеи приближается к краю. Я не знаю, насколько это портативно - кто-то в Интернете сказал, что getch () не работает на платформах, отличных от Windows. Трудно сказать, будет ли ASCII 1 выглядеть как смайлик.

Гольф-версия довольно раздражает, так как нет возможности изящно выйти из программы. Control-C не работает для меня. С другой стороны, версия без заглушки завершается, если вводится символ, отличный от 'w', 'a', 's' или 'd'.

Так называемый "негольфированный":

#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
источник
1

05AB1E , 23 байта

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

Попробуйте онлайн!

Объяснение:

                      # 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!

Grimmy
источник