休憩してヘビを作りましょう!


23

私たちの古典的なヘビは、成長ホルモンの不均衡を開発しました。さらに悪いことに、彼の尾は固定されています!で指定された方向入力が与えられFigure 1た場合、彼が成長する場所を決定するプログラムを作成します。

無駄に

図1.方向入力。

プログラム仕様

  • 入力文字を文字ごとに読み取りますSTDIN
  • 文字を読んだ後、ヘビをに出力STDOUTます。ヘビを印刷するたびに、間に空白行を含めてください。
  • ヘビはで構成され<>v^、頭。蛇の頭のようなあなたが選んだ任意の丸い文字であってもよくo0O、または
  • の任意の組み合わせが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<<<<

8
非常に素晴らしい。しかし... WTHは「コードgofl」ですか?
ジョンドヴォルザーク

2
独自のスネークと入力文字列を作成するのは簡単すぎるので、ボーナスを取り除きます。
ベータ崩壊

1
@JanDvorak腐った
hmatt1

1
@BetaDecay平面スケール。コードゴルフの例では、cの左上から始まりましたが、dの方が高いため、下に移動します。
hmatt1

2
@chilemagicありがとう!両方とも受け入れられる場合は、おそらく質問でこれを明確にする必要があります。
インゴバーク14

回答:


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}

ゴルフをしていない:

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:

OPの例の1つ:

ここに画像の説明を入力してください

Stretch Maniacの例:

ここに画像の説明を入力してください

非ゴルフ

これは、私が実際にゴルフを始める前のある時点からの(わずかに)未ゴルフバージョンです。

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

gifはとてもクールです。あなたが書いたスクリプトによって自動的に作成されますか?
AndoDaan

1
ありがとう!Googleの力で、Ubuntuでスクリーンレコーディングからギフトを作成する方法を調べました。スクリーンレコーダーとconvert。非常に簡単:)
インゴビュルク14

3
(ギフトではなく、gif)
IngoBürk14年

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'

以前の回答と同じアプローチですが、前後にカーソルを正しく配置します。私はカーソルの位置を決めるアプローチを非常に誇りに思っています。基本的には、文字を印刷せずに最初に蛇を逆に実行します。


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/$/@/'正しい出力が得られません。
インゴバーク14

実行後のプロンプトは、おそらくヘビの一部を上書きしています。パイピングの代わりにヘビを直接stdinに貼り付けるか、数\n秒後に追加し@てプロンプトが別の場所に移動するようにします。
スネフテル14

1
ヘビが上がったりボードの左に出たりすると失敗することがあります。
tomsmeding

@tomsmedingええ、私はそれを処理するためにそれを拡張するかもしれません。ただし、言語は別として、ANSI制御シーケンスはコードを短くする方法だと思います。
スネフテル14

3

Java-646

最初のものであるかもしれません!

きっとあなたはこれを打ち負かすことができます。

un(sort of)golfed

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

入力-dddsssdddwwwwaaaaaaaasssssssssssddddddddddddddddd

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

入力-dddsssdddddasddddwww

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

私の個人的なお気に入り-dwdwdwddaasassdddddwdwdwddsdswawaasassdddddddwdwdwddsdswawaasassddddwwwwwwwsssssssdsdsdddwwwwddaassddaassddddsssdddwdwdwddaasasassddddwwwwssssssssssddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddsddddswdsddddddwdwds

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

空白を含む「ゴルフなし」(これはゴルフ版と同期しません):

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バイト節約されます。ニシンです。
エリックアウトゴルファー16

@EʀɪᴋᴛʜᴇGᴏʟғᴇʀ は実際には3バイトとしてカウントされませんでした。
マーティンエンダー

@MartinEnder である必要があり、デフォルトのエンコーディングはUTF-8です。数えられない気がしました。私はそれが偶然であり、すぐにギリーによって修正されなければならないと感じています。
エリックアウトゴルファー16

@EʀɪᴋᴛʜᴇGᴏʟғᴇʀまあ技術的には、回答者はインタープリターでサポートされているエンコードを自由に使用できます(また、ASCII互換のコードページにはその文字が含まれていると確信しています)が、それは重要です。バイトカウントはを使用したO場合と同じであるため、心配する必要はありません。コードからは他のキャラクターでも機能することは明らかですが、これを使用すると、チャレンジからテストケースを変更せずに簡単に実行できます。
マーティンエンダー

@MartinEnder Pythonは、Unicode文字列をサポートする能力によって証明されたUTF-8を使用します。この機能を有効にするには、1行目または2行目がでなければなりません#coding=utf-8#coding=utf-16動作しないことに注意してください。したがって、3としてカウントする必要があります
エリックアウトゴルファー

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
プログラミングパズルとコードゴルフへようこそ!ヘルプセンターで概説されているルールに従って、課題に対するすべての解決策は、使用中の勝利基準の真剣な候補である必要があります。たとえば、コードゴルフコンテストへのエントリーはゴルフする必要があります。
デニス

1
バイトカウントを追加しましたが、削除したいスペースがたくさんあります。
マーティンエンダー

おかげで、私は私の最初のエントリに必要な変更を加えました。追加のアドバイスは大歓迎です。
アドリアーンエラスムス


@EʀɪᴋᴛʜᴇGᴏʟғᴇʀそれはただ印刷しSyntaxError: invalid syntaxます。
デニス

2

05AB1E35 34 30 28 バイト

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

0ヘビの頭として使用します。

@Grimyのおかげで-4バイト。

オンラインで試してください(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のヒント(辞書の一部ではない文字列を圧縮する方法および大きな整数を圧縮する方法?を参照して、.•₃º•is "adsw"およびŽO^is を理解してください6240

CanvasビルトインΛとその3つの引数の簡単な説明:

最初の引数:長さ:描画する線のサイズ。重複することに留意する必要があるため、すべてのキャラクターにサイズ2を使用し、ヘビの頭に追加の1を使用します。
2番目の引数:文字列:表示する文字。この場合の文字は、蛇の頭文字が追加されています。
3番目の引数:方向:与えられた長さのこれらの文字列を描画する方向。一般に、[0,7]これらの方向にマップする方向があります。

7   0   1
    
6  X  2
    
5   4   3

6240[,,,]

Canvasビルトインの詳細については、この05AB1Eのヒントを参照してくださいΛ


1
私は何かを逃したかもしれませんが、私はまったくγ必要とは思わない。これはうまくいくようです。
グリムミー

@Grimyありがとう、確かにそうです。ヘッドの2と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 

いくつかのトリック:

  • 警告と厳密な設定が有効になっていないため、ベアワードを使用できず、変数を使用する前に宣言しない
  • 太いコンマの代わりに細いコンマを使用して数文字を節約する
  • 不要な場合に変数の初期値を設定しない
  • 可能な場合はセミコロンを省きます
  • 使用する必要がないように、参照としてではなく配列とハッシュを定義する->
  • 幅と高さを必要以上に大きくして、正確に計算する必要がないようにします(余分なコードが必要になります)

痛いもの:

  • 文字列の文字数をカウントする組み込みの方法はありません(とにかく長くなっている可能性があります)
  • 組み込みの最小/最大関数がないため、それを実行するライブラリをインポートするために27文字を無駄にする必要があります(独自の定義よりも少ない)

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

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!

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.