幾何学的な挑戦


23

誰もがジオメトリを愛しています。では、なぜゴルフをコーディングしてみませんか?この課題には、文字や数字を取り入れ、それに応じた形を作ることが含まれます。

入力

入力はの形式になり(shapeIdentifier)(size)(inverter)ます。

しかし、shapeIdentifier、サイズ、およびインバーターは何ですか?

形状識別子は、*s で作成する形状のタイプの識別子です。形状識別子は次のとおりです。

  • s - 平方
  • t -三角形

サイズはの間1-20になり、それは図のサイズです。

インバーターは、形状が逆さまになるかどうかであり、a +またはaで示され-ます。注: s3-==(等しい)s3+正方形は対称であるため。ただし、t5-!=(等しくない)t5+

出力では末尾の空白は問題ありませんが、先頭の空白はそうではありません。

出力例

Input: s3+
Output:
***
***
***

Input: t5+

Output:
  *
 ***
*****

Input: t3-
Output:
***
 *

特記事項

三角形の入力は常に奇数になるため、三角形は常に*上部が1 で終わります。

三角形のサイズは、インバーターの場合は底辺 +のサイズであり、インバーターの場合は上部のサイズです-


3
、今のジオメトリを取って(最終的な幾何学の勉強)された者として、私は100%の確信を持って言うことができる:ジオメトリがすべて... Dでない、絶対に楽しいです:
のAshwinグプタ

回答:


9

Pyth、40 36 34 32バイト

@isaacgによる-1バイト

JstPz_W}\+zjl#m.[J*\*-J*}\tzyd;J

ラムダ内のセミコロンは、ラムダ変数のグローバル値であり、1バイトを節約する機能です。

                         Implicit: z = input
JstPz                    J = size.
_W }\+z                  Reverse if "+" in z
j l# m                J  Join the nonempty lines in map lambda d:... over range(J)
      .[J            ;   Pad the following with spaces (;) to length J
         *\*               "*", this many times:
            -J*}\tzyd        J if "t" not  in z,
                             otherwise the correct number for a triangle.

ここで試してみてください

テストスイート


1
余りに長いが、Japtを15バイト倒しますか?これがどのようにゴルフされるのか
楽しみです

いい解決策!最後の位置にしか表示できないため、に置き換えることqez\+でバイトを保存できます。}\+z+
isaacg

6

Pyth、38バイト

JsPtzj?}\szm*\*JJ_W}\-zm.[J*\*hyd;/hJ2

テストスイート

基本的には簡単です。2つのシェイプのロジックの一部を組み合わせることができればいいのですが、現在は別です。


5

JavaScript(ES6)、142 146 147

編集 1バイト保存THXの@ETHproductions 編集 2バイトSVE THX @ user81655

i=>([,a,b]=i.match`.(.+)(.)`,Array(l=i<'t'?+a:-~a/2).fill('*'.repeat(a)).map((r,i)=>l-a?(' '.repeat(i=b<'-'?--l:i)+r).slice(0,a-i):r).join`
`)

テスト(FireFoxで実行)

F=i=>(
  [,a,b]=i.match`.(.+)(.)`,
  Array(l=i<'t'?+a:-~a/2).fill('*'.repeat(a))
  .map((r,i)=>l-a?(' '.repeat(i=b<'-'?--l:i)+r).slice(0,a-i):r)
  .join`\n`
)

function test() { O.textContent=F(I.value) }

test()
Input: <input id=I oninput="test()" value="t11-"/>
<pre id=O></pre>


\d- > .、前と後に正確に一つの非数字があることが保証されていますので、
ETHproductions

右@ETHproductions、感謝
edc65

いいね これはJSの最適なアルゴリズムだと思いますが、もっと短いアルゴリズムは見つかりません。
ETHproductions

i.match(/.(.+)(.)/)->i.match`.(.+)(.)`
user81655

@ user81655素敵なヒント、ありがとう
edc65

5

Python 2、106バイト

s=raw_input()
n=int(s[1:-1])
for i in[range(1,n+1,2),n*[n]][s<'t'][::2*('+'in s)-1]:print('*'*i).center(n)

出力は完全な長方形で、各行には末尾のスペースが埋め込まれています。これは、OPのコメントに基づいて問題ないと思われます。

注:inputこれらのような問題に対してPython 2で許可されているかどうかはまだわかりません...


4

Japt、62 60 55 52 51バイト

V=Us1 n;U<'t?Vo ç*pV):0oV2 £S²pY iY'*pV-X})·z2*!Uf-

オンラインでお試しください!

最初に行う必要があるのは、図形の大きさを把握することです。これは非常に簡単です。

      // Implicit: U = input string, S = space
V=    // Set variable V to
Us1   // everything after the first char of U,
n;    // converted to a number. This turns e.g. "12+" into 12.

次に、出力の形状を整理します。

U<'t?      // If U comes before "t" lexicographically (here, if the first char is "s"),
Vo         //  make a list of V items,
ç*pV)      //  and set each item to V asterisks.
:0oV2      // Otherwise, create the range [0, V) with steps of 2 (e.g. 7 -> [0,2,4,6]),
£       }) //  and map each item X and index Y to:
S²pY       //   Repeat 2 spaces Y times. This creates a string of Y*2 spaces.
iY'*pV-X   //   At position Y in this string (right in the middle), insert V-X asterisks.
·          // Join with newlines.

これまでに、出力のサイズと形状を管理しました。残っているのは回転だけです。三角形は現在上向きになっているため、3番目の文字が次の場合はそれらを反転する必要があります+

!Uf-    // Take the logical not of U.match("-").
        // If U contains "-", this returns false; otherwise, returns true.
2*      // Multiply by two. This converts true to 2, false to 0.
z       // Rotate the list 90° that many times.
        // Altogether, this turns the shape by 180° if necessary.

そして暗黙の出力により、ここでの作業は完了です。:-)


4

パイソン2、235 193 167 157バイト

更新:

リスト内包表記とstr.center()を使用して、いくつかの重要な最適化を行いました。私はもう少しカントーをすることができると感じています、後でそれを新鮮に見せるつもりです。

更新2

Sherlock9の提案で10バイトを保存しました。どうもありがとう!:)

d=raw_input()
x=int(d[1:-1])
o="\n".join("*"*x for i in range(x))if d<"t"else"\n".join(("*"*i).center(x)for i in range(x,0,-2))
print o[::-1]if"+"in d else o

古い答え

d=raw_input()
x=int(d[1:-1])
if "s" in d:
 for y in range(x):
    o+="*"*x+"\n"
 o=o[:-1]
else:
 b=0
 while x+1:
    o+=" "*b+"*"*x+" "*b+"\n"
    x-=2
    b+=1
 o=o[:-1]
 if d[-1]=="+":
    o=o[::-1]
print o

かなり簡単なアプローチ。最後に出力する文字列の行ごとに行を書きます。三角形は常に反転して描画され、必要に応じて反転されます。文字列に整数を掛けることができるという事実は、多くのバイトを節約しました!

私はまだ少し経験が浅いので、もう少し後のゴルフを試みますが、その間に提案を歓迎します。

編集:コメントの助けを借りてそれをたくさんゴルフし、他のpython-answersの1つからサイズ計算を盗みました。このアルゴリズムでできることはそれだけだと思います。


どのように数えましたか?これを使用するとwc、235のバイトカウントが得られます。間違っていますか?
ბიმო

1
これは確かに235バイトです。ゴルフのアドバイス:2つのスペースの代わりにタブを使用します。これはPython 2で有効で、5バイト削ります。
ドアノブ

またraw_input、を使用する必要はありませんinput。使用すると、4バイト節約できます。さらに、2行目の括弧は必要ありません。これは、変数xをまったく使用しない(使用するif"s"in d)と、さらに9バイト節約できます。
1

2
ウィンドウ内@DenkerAffe場合カウント、各改行のために1つのバイトを減算-改行Windowsで2バイトであるが、他の環境では1バイト
edc65

1
最初に、[]join関数呼び出しの角かっこを削除できます。第二に、Pythonであるif d<"t"elseため短い"s3+"<"t"<"t3+"です。第三に、else"\n".joinそして.center(x)for。立つ瀬がない。必須ではありません。第四に、print o[::-1]if"+"in d else o私は2バイトのために物事を再配置(間に1つのスペース]ifし、他の間if"+"
Sherlock9

3

JavaScript、220バイト。

q=s=>+s.slice(1,s.length-1);f=s=>s[0]=="s"?("*".repeat(q(s))+"\n").repeat(q(s)):Array.apply(0,Array(-~(q(s)/2))).map((_,n)=>(s[s.length-1]=="-"?~~(q(s)/2)-n:n)).map(n=>(" ".repeat(q(s)/2-n)+"*".repeat(n*2+1))).join("\n")

で実行 f(input here)

ここで試してみてください!

正方形には末尾に改行がありますが、三角形にはありません。説明:

q=s=>+s.slice(1,s.length-1);                                                                                                                                                                                                 Define a function, q, that takes returns the argument, without the first and last character, casted into an integer.
                            f=s=>                                                                                                                                                                                            Define a function, f, that takes one argument, s. (This is the main function)
                                 s[0]=="s"?                                                                                                                                                                                  If the first character of s is "s" then...
                                           ("*".repeat(q(s))     )                                                                                                                                                           Repeat the "*" character q(s) times.
                                           (                +"\n")                                                                                                                                                           Append a newline to that
                                                                  .repeat(q(s))                                                                                                                                              Repeat that q(s) times.
                                                                               :                                                                                                                                             Else... (the first character of s isn't "s")
                                                                                Array.apply(0,Array(          ))                                                                                                             Create an array of length...
                                                                                Array.apply(0,Array(-~(q(s)/2)))                                                                                                             floor(q(s)/2)+1
                                                                                                                .map((_,n)=>                                   )                                                             Map each element, _ with index n to...
                                                                                                                .map((_,n)=>(s[s.length-1]=="-"?              ))                                                             If the last element of s is "-" then...
                                                                                                                .map((_,n)=>(s[s.length-1]=="-"?~~(q(s)/2)-n  ))                                                             floor(q(s)/2)-n
                                                                                                                .map((_,n)=>(s[s.length-1]=="-"?            : ))                                                             Else...
                                                                                                                .map((_,n)=>(s[s.length-1]=="-"?             n))                                                             Just n
                                                                                                                                                                .map(n=>                                        )            Map each element into...
                                                                                                                                                                .map(n=>(" ".repeat(q(s)/2-n)                   )            Repeat " ", q(s)/2-n times.
                                                                                                                                                                .map(n=>(                   )+"*".repeat(n*2+1)))            Append "*", repeated 2n+1 times.
                                                                                                                                                                .map(n=>(" ".repeat(        )+"*".repeat(n*2+1))).join("\n") Join with newlines

最初の行の長さは338文字です。モニターを1つ半表示します。
-isanae


1
ランダムなtinyurlリンクはクリックしませんが、もう一度確認してください。いずれにせよ、コードボックス内のスクロールバーは避けてください。読みにくくなります。
isanae

1
@Loovjo彼は説明の最初の行を意味すると思います。通常、JavaScriptの回答ではこのスタイルではなく説明をインデントします。そのため、その半分を表示するためにスクロールする必要はありません。
user81655

@ user81655はい、私は説明で意味しました。今、私は混乱を理解しています!
-isanae

3

パイソン2、157の 132バイト

def f(s):
 S=int(s[1:-1])
 for n in([range(1,S+2,2),range(S,0,-2)]['-'in s],[S]*S)['s'in s]:
  print "{:^{S}}".format('*'*n,S=S)

最初の試み+/-は、最後にオプションがあり、それを取り除くことで束を剃ることを可能にしました

ここでの考え方は、汎用出力にスローできるリストを作成することです。最も難しい部分は、入力から長さを分離していました。


長さを取得するためx=int(d[1]if len(d)<4 else d[1:3])に、入力文字列としてd を使用しました。それは、ソリューションよりも5バイト短いです。あなたはまだ私のPythonの答えをはるかに上回っています、あなたがそこで何をしたかを理解して、次回あなたを打ち負かしてください!:)
デンカー

1
実際にx=int(d[1:-1])はそれよりずっと短いです。他のPythonの答えで見ました。
デンカー

私は、インバータはオプションであることを覚えて何らかの理由@DenkerAffe、ので、それは動作しないでしょうが、私はちょうどその作ら推測
wnnmaw

2

網膜102 85バイト

バイトカウントは、ソースコードがISO 8859-1としてエンコードされていることを前提としています。

\d+
$0$*:¶
^((\w)+):(:+)
$1$2$3$2¶$0
m`s$|:t

)`(.+)¶-(\D*)
-$2¶$1
m`^.

G`.
T`ts:` *

オンラインでお試しください。

あとでこれをゴルフしてみます。


Notepad ++は、コードは85バイトではなく89バイトだと言います。ISO-8859-1エンコーディングを使用し\nました\r\n。コンテンツのBase64:XGQrCiQwJCo6wrYKXigoXHcpKyk6KDorKQokMSQyJDMkMsK2JDAKbWBzJHw6dAoKKWAoLispwrYtKFxEKikKLSQywrYkMQptYF4uCgpHYC4KVGB0czpgICo=(Notepad ++からの直接コピー)。不気味なことに、すべてのオンラインソリューションは私に85を与えるバイト...ハム...
イスマエルミゲル

@IsmaelMiguel Notepad ++がをカウントする方法については、何かおかしなことがあります。これらは間違いなくISO 8859-1のシングルバイトです(値は182)。
マーティンエンダー

2

真剣に、54バイト

,#i's=`≈;'**@½≈";#dXdXεj' +"£n`@`≈;'**n`@Iƒ('-=WXa0WXü

オンラインで試す

,#i                                                    Take input, push chars separately
   's=                                   Iƒ            IF the first char is "s":
                                `      `@                run the quoted function
                                 ≈;'**n                  make list of n strings of n *'s
      `                       `@                       ELSE run the quoted function:
       ≈;                                                make two copies of int n
         '**                                             use one to make string of n *'s
            @½≈                                          cut the other in half (e.g. 5->2)
               "           "£n                           run n/2 times the quoted function:
                ;#                                        copy the string as list of chars
                  dXdX                                    discard the last 2 *'s
                      εj                                  join back into string
                        ' +                               prepend a space
                                           ('-=WX 0WX  IF the third character is "-":
                                                 a       invert the stack
                                                     ü pop and print the entire stack

@Mego:あれ#dXdXεj?ストリングスライシング????


2

ES6、178の 172 159バイト

s=>(p=s.match(/d+|./g),u=n=+p[1],m=n+1>>1,t=' '.repeat(n)+'*'.repeat(n),v=s<'t'?0:p[2]<'-'?(u=m,1):-1,[...Array(s<'t'?n:m)].map(_=>t.substr(u,u,u+=v)).join`
`)

これは、私が行った興味深い観察によるものです。あなたが繰り返した場合はn、スペースやnアスタリスクをあなたが得る(例えば用n=5)この:

     *****

次に、同じ開始と同じ長さの部分文字列を取得します。

     |*****| (5)
    | ***| (4)
   |  *| (3)

これらの部分文字列は、まさに必要な文字列ですt5

編集:@ edc65のおかげで6バイトを保存しました。

編集:u+=vの3番目の引数を非表示にsubstrすることで13バイトを節約したため、初期化を簡素化できます。


@ThomasKwaえっ、私は固定のだ後にtそれがあることが判明した処理コードwとはu同等になったが、それが戻ってダウン178に私を取るために私に十分なバイトを保存!
ニール

[,b,c]=s.match以降s<'t'...いくつかのバイトを保存する必要があります(Firefoxのみ)
edc65

@ edc65マッチを保存しないだけで、6バイト節約したものsを使用できs<'t'ます、ありがとう。
ニール

2

MATL、48バイト

' *'jt4Y2m)U1$l't'Gm?2MQ2/:1L3$)R!P!R'+'Gm?P]]Q)

言語/コンパイラの現在のバージョン(10.1.0)を使用します。

コードは、任意の順序で入力文字を受け入れます:all s11+11s+さらには1+s1有効な入力文字列です。

編集(2016年7月30日):リンクされたコードは、言語の最近の変更に合わせて置き換え1L3$)られY)ます

オンラインでお試しください!

説明

' *'        % push string. Will be indexed into to obtain final result
j           % input string
t           % duplicate
4Y2         % predefined literal string '0123456789'
m           % logical index of digits in input string
)           % index into input string to obtain substring with digits
U           % convert to number
1$l         % generate square of ones with that size
't'         % push character 't'
G           % push input string
m           % true if input string contains 't'
?           % if so...
  2M        % push argument of call to function `l`, i.e. square size
  Q2/       % add 1 and divide by 2. Call result T
  :         % generate vector [1, 2, ... T]
  1L        % predefined literal representing Matlab's `:` index
  3$)       % two dimensional index. Transforms square into rectangle
  R         % remove (set to zero) lower-left corner
  !P!       % flip horizontally
  R         % remove lower-left corner. This gives inverted triangle
  '+'       % push character '+'
  G         % push input
  m         % true if input contains '+'
  ?         % if so...
    P       % flip vertically
  ]         % end if
]           % end if
Q           % add 1. This gives array of values 1 and 2
)           % index string ' *' with this array to produce char array
            % implicitly display that char array

1

C、259バイト

#define x(y);)putchar(y)
#define m(n)for(n=0;n++<
#define T {m(q)i x(32);m(q)s-i*2 x(42);puts("");}
main(q,v,i,s)char**v;{s=atoi(v[1]+1);if(*v[1]=='s')m(i)s*s x(42)&&!(i%s)&&puts("");else if(strchr(v[1],'+'))for(i=s/2+1;i-->0;)T else for(i=-1;i++<s/2+1;)T}

食べない

main(q,v,i,size)char**v; // neat way of declaring variables
{
    size=atoi(v[1]+1);
    if(*v[1]=='s')
    {
        for(i=0;i++<size*size;)
        {
            putchar(42); // returns 42 (true)
            if(!(i%size))
                puts("");
        }
    }
    else if(strchr(v[1],'+')) // if finds plus sign
    {
        for(i=size/2+1;i-->0;) // iterate the height of the triangle
        {
            for(q=0;q++<i;)putchar(32); // conveniently i is the number os spaces before each line
            for(q=0;q++<size-i*2;) putchar(42);
            puts("");
        }
    }
    else for(i=-1;i++<size/2+1;) // does the same as above but inverted order
    {
        for(q=0;q++<i;)putchar(32);
        for(q=0;q++<size-i*2;)putchar(42);
        puts("");
    }
}

提案や批評は大歓迎です。


1

ルビー、99

->s{n=s[1,2].to_i
n.times{|i|d=(s.ord-115)*(s[-1]<=>?,)*(n-1-i*2)
d<1&&puts((?**(n+d)).center(n))}}

高さの正方形または三角形算出n及び平均幅 n(先端で2N-1ベース、1である幅算出三角形。ように)は、それだけ辺の傾きをveryingによって印刷超えないそれらの行をn文字をます。

テストプログラムに参加していない

f=->s{                         #take a string as an argument
  n=s[1,2].to_i                #take 2 characters starting at index 1 and convert to a number for the size
  n.times{|i|                  #iterate through n rows    
    d=                         #calculate how many stars "MORE THAN" n we need on a row
    (s.ord-115)*               #ascii code for 1st character of string - 115 : s-->0, t-->1
    (s[-1]<=>?,)*              #compare last character of input with comma character - --> +1 + --> -1
    (n-1-i*2)                  #row number * 2: 0 at centre, positive above it, negative below it
    d<1&&                      #only output if d is nonpositive (i.e we need less than n or exactly n stars)
    puts((?**(n+d)).center(n)) #print n+d stars, centred in a field of n characters padded by whitespace
  }
}

f[gets.chomp]

1

Jolf、37バイト、非競合

このチャレンジが投稿された後に機能を追加したので、これは受け入れられるとは考えられません。これはISO-8859-7でエンコードされています。ここですべてのテストケースを試してください

onFiΒ€ioSgiγ?='sn―sΒ'*―TΒ1'*?='-SZiγγ

パート1:文字列の解析

onFiΒ€ioSgi
on          set n to
  Fi         the first entity of i (the shape identifier)
    Β       set Β (beta) to
     €i      the "inside" of i (in this case, the size) as a number
       oS   set S to
         gi  the last entity of i (the inverter)

パート2:結果を取得する

γ?='sn―sΒ'*―TΒ1'*
γ                 set γ (gamma) to the result of the following expression
 ?='sn             if n is the character s,
      ―sΒ'*         then return a pattern "s" (a square) made with "*"s
           ―TΒ1'*    otherwise, return a pattern "T" (triangle) that is centered and
                     has a scale factor of 1, made with "*"s

パート3:結果の反転

?='-SZiγγ
?='-S     if S is a "-"
     Ziγ   return γ, inverted across its lines
        γ  otherwise, return γ untouched
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.