レモンライム文字列


34

空でない単一行の文字列を取り込むプログラムまたは関数を作成します。スペースを除いて印刷可能なASCIIのみが含まれていると想定できます。

文字列のプレフィックスから作られたレモンやライムに似たASCIIアート菱形の形状を印刷または返します。

入力文字列の長さがn文字であるとします。そして、このような形状で構成されて2N - 1つの縫い合わさASCIIアートの列、各なる2N - 1行。1から数えて、k番目の列はf(k)= min(k、2n-k)文字幅で、入力の最初のf(k)文字のf(k)コピーを含み、縦方向に中央揃えで、単一の空白を持ちます。コピーを分離する行。

たとえば、入力がのLemon場合、出力は次のようになります。

          Lemon
      Lemo     Lemo
   Lem    Lemon    Lem
 Le   Lemo     Lemo   Le
L  Lem    Lemon    Lem  L
 Le   Lemo     Lemo   Le
   Lem    Lemon    Lem
      Lemo     Lemo
          Lemon

入力がlime出力の場合:

      lime
   lim    lim
 li   lime   li
l  lim    lim  l
 li   lime   li
   lim    lim
      lime

そして、他の入力についても同じパターンに従います。

a

a

Be

 Be
B  B
 Be

/\

 /\
/  /
 /\

cat

   cat
 ca   ca
c  cat  c
 ca   ca
   cat

|||

   |||
 ||   ||
|  |||  |
 ||   ||
   |||

.__.

      .__.
   .__    .__
 ._   .__.   ._
.  .__    .__  . 
 ._   .__.   ._
   .__    .__
      .__.

$tring

               $tring
          $trin      $trin
      $tri     $tring     $tri
   $tr    $trin      $trin    $tr
 $t   $tri     $tring     $tri   $t
$  $tr    $trin      $trin    $tr  $
 $t   $tri     $tring     $tri   $t
   $tr    $trin      $trin    $tr
      $tri     $tring     $tri
          $trin      $trin
               $tring

出力の行には末尾にスペースが含まれる場合があり、オプションの末尾改行が1つある場合があります。

バイト単位の最短コードが優先されます。


13
プレフィックスのみを使用していることに驚きました-左側にプレフィックスがあり、右側にサフィックスがあることを期待していました!
ニール

1
(実際にコーディングPOVから私は全体に接尾辞を好むでしょうが、ケーキを持って食べることはできません。)
ニール

2
「定義レモンやライムに似た形状
ピーター・テイラー

6
@PeterTaylor例で示されている形状。正直なところ、出力を推測できない入力文字列はありますか?
カルビンの趣味

6
何も推測する必要はありません。質問には仕様が必要です。
ピーターテイラー

回答:


11

MATLAB、140の136 128 124バイト

基本的には、最初に中間セクションから開始し、次に短縮/変更バージョンをステップごとに追加/追加します。

a=input('');v=ones(nnz(a)*2-1,1)*a;v(2:2:end,:)=0;b=v;for k=a;v=v(2:end,1:end-1);v(end+1,:)=0;b=[v,b,v,''];end;b(~flip(b))=0

8バイト@LuisMendoをありがとう!

MATLAB

               MATLAB               
          MATLA      MATLA          
      MATL     MATLAB     MATL      
   MAT    MATLA      MATLA    MAT   
 MA   MATL     MATLAB     MATL   MA 
M  MAT    MATLA      MATLA    MAT  M
 MA   MATL     MATLAB     MATL   MA 
   MAT    MATLA      MATLA    MAT   
      MATL     MATLAB     MATL      
          MATLA      MATLA          
               MATLAB                    

ああ、クールなアイデア!残念ながら私の古いバージョンにはありませんflip:/
flawr

R2015bで124バイトのコードをテストし、動作することを確認しました
ルイスメンドー

U O thaのn個のk Y!
flawr

7

Python 2、121 110バイト

s=input()
n=len(s)
r=range(1,n)+range(n,0,-1)
for y in r:print''.join(s[:(x+y-n&(x+y>n))*x]or' '*x for x in r)

を使用する場合は116バイトraw_input。このプログラムは、基本的に、中心からのL1-ノルム/マンハッタン距離、および入力長のパリティと比較したこの距離のパリティに基づいてマスクを実行します。

(-9バイトの@Lynnに感謝し、さらに2バイトの道を開いた)


飛び出すのは、最初の2行をl = len(input())に圧縮できることです。
フランク

@Frankは、sその者のことはできませんので、残念ながら、長い行の最後に使用されている
SP3000

Python 2は、のわずかに異なる選択を使用して112または116バイトを取得できますR
リン

ああ、私はそれをキャッチしませんでした、ごめんなさい。
フランク

@Lynn Ohうわー、その選択Rは、コードをすっきりさせます!
Sp3000


6

JavaScript(ES6)、132バイト

s=>{x=' '.repeat(l=s.length);for(n=r='';n++<l;r=r?t+`
${r}
`+t:t)for(i=l,t='';i;t=t?w+t+w:w)w=(i<n|n+i&1?x:s).slice(0,i--);return r}

テスト

var solution =

s=>{
  x=' '.repeat(l=s.length);
  for(n=r='';n++<l;r=r?t+`\n${r}\n`+t:t)
    for(i=l,t='';i;t=t?w+t+w:w)
      w=(i<n|n+i&1?x:s).slice(0,i--);
  return r
}

result.textContent = solution('Lemon');
<input type="text" id="input" value="Lemon" oninput="result.textContent=solution(this.value)" /><pre id="result"></pre>




2

JavaScript、187 178バイト

ビット単位のアプローチ。関数m2 ** length、たとえば00100バイナリで開始し、m(n) = m(n-1) << 1 | m(n-1) >> 1前半を定義することでマスクを定義します。興味深いことに、後半はとして定義できますm(n) = m(n-1) << 1 & m(n-1) >> 1。(プログラムは代わりにm(n) = m(2 * length - 1)後半を定義することを選択します)ここから、これらのマスクを使用して、単語またはスペースを表示するかどうかを確認して確認でき2 ** column & m(row)ます。もちろんJavaScriptでは2 ** something1 << something...

注:疲れている間に書かれています。ほぼ確実にミスをしていません。

s=>{m=n=>n?n>l?m(2*l-n):(p=m(n-1))>>1|p<<1:1<<l
for(r=0;r/2<=(l=s.length-1);r++){for(i=1,o="";i/2-1<l;i++)o+=(1<<i-1&m(r)?s:" ".repeat(i)).slice(0,i>l?2*l+2-i:i)
console.log(o)}}

2

Haskell、109バイト

f s|n<-length s,r<-[1..n]++[n-1,n-2..1]=unlines[do x<-r;min(" ~"!!mod((x+y+n)*min(n-x-y)0)2)<$>take x s|y<-r]

2

Brachylog、46バイト

{a₀⟨{;Ṣ}j₎l⟩}ᶠL&l;Ṣj₍ẹa₁ᶠ;Lz{czzcᵐ}ᵐ⟨kc↔⟩zcᵐ~ṇ

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

ひどいバイトカウントとおそらくより悪いアプローチ(BrachylogはASCIIアート用に正確に設計されていないことは言うまでもありませんが)とにかく投稿するのに十分な時間を無駄にしました。

              L    The variable L
{           }ᶠ     is a list containing every possible
 a₀                prefix of
                   the input
    {;Ṣ}           paired with a space
        j          and concatenated with itself
   ⟨     ₎l⟩       a number of times equal to its length.
          ᶠ    A list containing every possible
        a₁     suffix of
   Ṣ           a space
    j          concatenated with itself
  ;  ₍         a number of times equal to
 l             the length of
&              the input
      ẹ        then split back up into its elements
               is an important list which doesn't actually get a name.
                         That list
;Lz                      zipped with L
   {     }ᵐ              with each pair being
    c                    concatenated,
     z                   zipped with cycling,
      z                  zipped back,
        ᵐ                and subjected to each of its elements being
       c                 concatenated itself,
           ⟨kc↔⟩         then palindromized
                z        and zipped yet again
                 cᵐ      with every line concatenated once more
                   ~ṇ    and finally joined on newlines
                         is the output.

このいずれかの唯一の巧妙な部分は、a₁最初a₀に単語のプレフィックスを最小から最初に生成し、プレフィックスzzの幅に一致するスペースのブロックに単一のスペースを拡張するための使用です。


1

TSQL、259バイト

ゴルフ:

DECLARE @ VARCHAR(30)='TSQL'

,@o VARCHAR(max),@i INT=0,@j INT,@t VARCHAR(max)SET @j=LEN(@)z:WHILE @i<LEN(@)SELECT @o=x+ISNULL(@o+x,''),@i+=1FROM(SELECT LEFT(IIF((@j-@i)%2=1,@,SPACE(99)),LEN(@)-@i)x)z SELECT @j-=1,@t=@o+ISNULL(CHAR(10)+@t+CHAR(10)+@o,''),@o=null,@i=0IF @j>0GOTO z PRINT @t

ゴルフをしていない:

DECLARE @ VARCHAR(30)='TSQL'

,@o VARCHAR(max),@i INT=0,@j INT,@t VARCHAR(max)SET @j=LEN(@)
z:
WHILE @i<LEN(@)
  SELECT @o=x+ISNULL(@o+x,''),@i+=1
  FROM(SELECT LEFT(IIF((@j-@i)%2=1,@,SPACE(99)),LEN(@)-@i)x)z
SELECT @j-=1,@t=@o+ISNULL(CHAR(10)+@t+CHAR(10)+@o,''),@o=null,@i=0
IF @j>0 GOTO z

PRINT @t

フィドル


0

C、167バイト

このプログラムは、入力テキストがプログラムへの最初のパラメーターとして(コマンドラインまたはその他を介して)渡されることを想定しており、出力をstdoutに書き込みます。

int i,j,k,l,v;main(h,s)char**s;{h=strlen(s[1]);l=h*2;for(;++i<l;puts(""))for(j=0;++j<l,v=j<h?j:l-j;)for(k=0;k++<v;putchar((i+j+h%2)%2&&v>h-(i<h?i:l-i)?s[1][k-1]:32));}

合理的な挑戦のように思えたので、これはここでのコードゴルフでの私の最初の試みです。したがって、おそらく私がやった方法のためにできた以上にゴルフができるでしょう。

説明

/* Static variables
   i - "Row" number
   j - "Column" number
   k - String character counter
   l - Double length of the input string
   v - Inverted column distance from center */
int i,j,k,l,v;

/* Main parameters
   h - (argc) Input string length
   s - argv */
main(h, s)
char**s;
{
  /* Assign the input string length and double length */

  h = strlen(s[1]);
  l = h * 2;

  /* Display content */

    /* Loop over rows l - 1 times and put a newline after each */
  for (; ++i < l; puts(""))
      /* Loop over columns l - 1 times and set the inverted column
         distance each time */
    for (j = 0; ++j < l, v = ((j < h) ? j : l - j);)
        /* Loop over characters up to the inverted column distance from the
           center (this generates the pattern of output lengths needed) */
      for (k = 0; k++ < v;)
        putchar(
            /* Check for if the current row + column (with an offset based on
               the input parity) parity is even or odd, creating the needed
               checkerboard pattern */
          (i + j + h % 2) % 2 &&
            /* If the inverted column distance from the center is more than the
               row distance from the center, then the cell is inside the
               circular shape */
          v > (h - ((i < h) ? i : l - i)) ?
              /* Display the requested character (minus one for 0 based) */
            s[1][k-1] :
            32 /* Otherwise display a space (ASCII 32) */
        );
}

入力の範囲の(n < m) ? n : (m * 2) - n中心位置からの反転距離を得るためにプログラムでの使用を少なくとも2回記録することは十分に重要です。それを行うより短い方法がある場合、このアルゴリズムはこのプログラムがどのように機能するかにとって重要であるため、より簡単にゴルフダウンすることができます。mm * 2n


0

C、137バイト

x,y,w;main(l,v)char**v;{for(y=l=strlen(v[1]);-l<--y;putchar(10))for(x=l;-l<--x;printf("%*.*s",w,w,x+y+l&1&&w>abs(y)?v[1]:""))w=l-abs(x);}

壊す:

これは、2n-1 x 2n-1グリッドのすべての要素を描画し、現在の要素を空白にするか入力語にするかを決定するマスク関数を使用します(マスクはひし形と市松模様をチェックします)。

x,y,w;
main(l,v)char**v;{
    for(y=l=strlen(v[1]);-l<--y;/*...*/)    // row loop (count down to save bytes)
        for(x=l;-l<--x;/*...*/)             // column loop
            w=l-abs(x);                     // calculate current word's width
            printf("%*.*s",                 // print...
                w,w,                        // ...with min & max width...
                x+y+l&1&&w>abs(y)           // Check mask:
                    ?v[1]                   //  ...word
                    :"")                    //  ...or blank space
        putchar(10)                         // Newline
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.