のこぎりのアルファベットを描く


42

今日はシンプルなもの。高さに正の整数を指定して「のこぎりのアルファベット」を描く最短のプログラムを作成します。プログラミング言語の名前は、それが始まる文字になったら書く必要があります。

たとえば、言語がPythonで、入力が1出力の場合は次のようになります。

ABCDEFGHIJKLMNOPythonQRSTUVWXYZ

入力が2出力の場合:

 B D F H J L N Python R T V X Z
A C E G I K M O      Q S U W Y

入力が4出力の場合:

   D     J     Python     V
  C E   I K   O      Q   U W
 B   F H   L N        R T   X Z
A     G     M          S     Y

ノート

  • A 常に左下から始まります。
  • 入力には、stdinまたは関数呼び出しなどを使用できます。stdoutへの出力。
  • 上記の入力26は機能する必要はありません。
  • 末尾のスペースはありません。

9
1文字の名前のプログラミング言語は許可されますか?(C、J、Kなど)
isaacg 14

@isaacgはい。それらの方が簡単かもしれないと思います。
カルビンの趣味14

1
入力が変数に格納されると単純に期待できますか?
マーティンエンダー14

@MartinBüttnerはい、大丈夫です。
カルビンの趣味14

13
ところで、これはのこぎり波ではなく、これは三角波です:P
qwr 14

回答:


14

nが高さを保持する場合:

C +エスケープコード:81

x;main(y){for(y=n--;x<26;x++)printf("\033[%d;%dH%c",n?x/n&1?y++:y--:y,x+1,x+65);}

C:110

x;char a[702]={[0 ...701]=32};main(y){for(y=--n;x<26;a[x*27-1]=10)a[27*(n?x/n&1?y++:y--:y)+x]=x+++65;puts(a);}

5
敗北を認めます。一体全体。:D
マーティンエンダー14

コンパイル手順をお願いできますか?ccエラー「<bebe.c:1:17:error: 'n'
undeclared

2
それは見た目よりずっと悪いです。まず、2番目の行には末尾のスペースが含まれます。2番目の行は、両方nがあなたの選択した番号に設定されたグローバル変数です(Martinが以前に尋ねたように)。
ベベ14

ああ、私はできる限りnを提供しなければなりません。笑。まだ感銘を受けました。
マナトワーク

19

C、134

n,m,c,p;
main(r){
for(scanf("%d",&n),m=--n?n*2:1;n+r--;puts(""))
for(c=-1,p=1;c++<25;)
p+=(c-n-r)%m*((c-n+r)%m)?1:1-printf("%*c",p,c+65);
}

いくつかの警告とともにgccでコンパイルします。改行は文字数に含まれません。

入力が既にに保存されてnいる場合、122文字

user2992539tolosおよびedc65の改善に感謝します。


3
puts("")代わりに使用できますprintf("\n")
ソムニウム14

2
4つの文字保存p-=(c-n+r)%m*((c-n-r)%m)?0:printf("%*c",p,c+65);の代わりにif((c-...

1
前の(削除された)コメントで申し訳ありません。間違っていました。記号で遊んで、パラメータがない場合、mainの最初の引数が1であるという事実を悪用しますn,m,c,p; main(r){ for(scanf("%d",&n),m=--n?n*2:1;n+r--;puts("")) for(c=-1,p=1;c++<25;) p+=(c-n-r)%m*((c-n+r)%m)?1:1-printf("%*c",p,c+65); }
。134

13

TI-BASIC-148バイト(生テキスト)、186バイト(グラフィック)

OPに対応して、素晴らしいTI-83(およびそれ以降)には、サイズが16 x 8(標準の大きなテキストを使用)または94 x 62ピクセル(小さなテキストでは約10行の価値があります) )。

さて、これには少し問題があります(説明をお願いします)。インタープリターはサイズの面付けを「無視」できません。つまり、ノコギリ歯の高さを20に設定しようとすると、コードの完全な実行を妨げるエラーが発生します。私は可能性があり、それがマシン上で実行されないだろう除き、無限の環境で、正しい出力を生成するコードを記述します。

これを言って、プログラムの(実行中の)バージョンを紹介します。これらはすべて、N実行する前に行で目的の高さに設定されている変数に依存します。

  • 生テキストのアプローチ

    :ClrHome
    :"ABCDEFGHIJKLMNOPQRSTI-BASICUVWXYZ"→Str1
    :8→R
    :For(C,1,16
    :If N=1
    :Then
    :0→F
    :Else
    :If R<2 or 10-R>N
    :1→F
    :If R>7
    :-1→F
    :End
    :If C≠20
    :Then
    :Output(R,C,sub(Str1,C,1
    :Else
    :Output(R,C,sub(Str1,C,8
    :C+7→C
    :End
    :R+F→R
    :End
    

    端末に関係なくこの機能を使用するには、上限チェック()に変更For(C,1,16For(C,1,33て削除しR<2 orます。出力は5→N次のとおりです。

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

  • グラフィックアプローチ(AxisOffわかりやすくするために必要な場合もあります)

    :ClrDraw
    :N*6→N
    :"ABCDEFGHIJKLMNOPQRSTI-BASICUVWXYZ"→Str1
    :57→R
    :For(C,1,56
    :If N=6
    :Then
    :0→F
    :Else
    :If R<7 or 64-R>N
    :6→F
    :If R>51
    :-6→F
    :End
    :If C≠20
    :Then
    :If C>50
    :Then
    :Text(R,C,sub(Str1,C-23,1
    :Else
    :Text(R,C,sub(Str1,C,1
    :End
    :Else
    :Text(R,C,sub(Str1,C,8
    :C+30→C
    :End
    :R+F→R
    :End
    

    これは正常に機能しますが、2つの小さな癖があります。幅は問題ありませんが、高さは依然として問題です。ただし、文字の間隔を空けなかったので、場合によっては(文字がノコギリから上昇または下降し始めるとき)、文字が後続の文字で切り取られることがあります。端末に関係なく動作させるには、上限チェック(R<7 or)を削除します。次に、グラフに従います。

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


今、これをグラフ計算機に移植しなければなりません
リアム・マッキンロイ

クイックコメント:トークン化された後、1バイトを節約0→FすることができますDelvar F。また、私は必ず座標のインラインブールテスト条件にエンドのおかげへの出力/テキストを考慮することができますよ、とのためにC+7→C、短期的にそれを書く場合には(そして/他/終了)
Adriweb

11

Pure Bash(coreutilsなし)、181バイト

m=$1
for l in A Bash {C..Z};{
((m))||s=++
((m>$1-2))&&s=--
for((m=$1==1?1:m,m$s,i=0;i<$1;i++));{
((i-m))&&a[i]+=${l//?/ }||a[i]+=$l
}
}
shopt -s extglob
printf %s\\n "${a[@]%%+( )}"

出力:

cat -E末尾の改行がないことを証明するためだけにパイプされています。

$ ./sawtooth.sh 1 | cat -E
ABashCDEFGHIJKLMNOPQRSTUVWXYZ$
$ ./sawtooth.sh 5 | cat -E
       E       M       U$
      D F     L N     T V$
     C   G   K   O   S   W$
 Bash     H J     P R     X Z$
A          I       Q       Y$
$ 

10

JavaScript(ES6)231 244

編集バグ修正、いくつかの並べ替え、およびheight == 1を管理する別の方法
さらに、これがOPで許可されているため、入力用のprompt()がない関数に変更されました。

このチャレンジにはおそらく最適ではない一般的なアルゴリズムへの変更はありません

F=h=>{for(p=s=[i=z=b=t=''];++p<h;)i=1,z=b=' ',s[p]=t;for(p=--h,k=64;++k<91;)s[p]+=t+String.fromCharCode(k),k-74||(s=s.map((x,q)=>x+(p-q?'         ':'avascript'))),p-=i,p<0|p>h?(i=-i,p-=i+i,t=z,b=t+t):t+=b;console.log(s.join('\n'))}

説明した

F=h=>{
  // row in s for output must be initialized to ''. In the same step I make other initializations
  for(p=s=[i=z=b=t='']; ++p < h;) // initialize for height 1, all increment and spacing can be null
    i=1,z=b=' ',s[p]=t; // the for body is entered only if height > 1, initializing spacing and increment to the right values
  for(p=--h,k=64;++k<91;)
    s[p]+=t+String.fromCharCode(k),
    k-74||(s=s.map((x,q)=>x+(p-q?'         ':'avascript'))), // if 'J' modify each line of output adding the name or spacing
    p-=i,p<0|p>h?(i=-i,p-=i+i,t=z,b=t+t):t+=b; // index bouncing
  console.log(s.join('\n'))
}

1

ABCDEFGHIJavascriptKLMNOPQRSTUVWXYZ

3上がる

  C   G            K   O   S   W
 B D F H Javascript L N P R T V X Z
A   E   I            M   Q   U   Y

上に4

   D     Javascript     P     V
  C E   I          K   O Q   U W
 B   F H            L N   R T   X Z
A     G              M     S     Y

7下がる

      G                    S
     F H                  R T
    E   I                Q   U
   D     Javascript     P     V
  C                K   O       W
 B                  L N         X Z
A                    M           Y

9

JAVA (393)

いつものゴルフの素晴らしい言語:

public class P{public static void main(String[]a){int h=Integer.valueOf(a[0]);String x="ABCDEFGHIJKLMNOPQRSTUVWXYZ";String[]l=new String[h];Arrays.fill(l,"");int i=h-1;int d=-1;for(char c:x.toCharArray()){for(int n=0;n<l.length;n++){String k=(n==i)?(c=='J')?"Java":c+"":(c=='J')?"    ":" ";l[n]+=k;}if(i==0&&d==-1)d=1;if(i==h-1&&d==1)d=-1;if(h>1)i+=d;}for(String s:l){System.out.println(s);}}}

2
残念ながら、のインポートを忘れましたjava.util.Arrays;。:-(
ジャスティン14

ただし、コードを改善することができます。ループヘッダーを削除しString x="ABC...Z";、に置き換えfor(char c...ますfor (char c=65;++c<91;){。Javaの文字が大好きです=)
flawr

さらに、置き換えることができるc=='J'c==74、合計で2つのバイトを保存します。
flawr 14

2
これらのifステートメントにいくつかのXORを使用すれば、より良い結果を得ることができると確信していますが、ここでは私の改良版です:(325)public class p{public static void main(String[]a){int h=Integer.valueOf(a[0]),i=h-1,d=-1,n;String[]l=new String[h];for(n=0;n<h;l[n++]="");for(char c=64;++c<91;){for(n=0;n<h;n++){String k=n==i?c==74?"Java":c+"":c==74?" ":" ";l[n]+=k;}if(i==0&d==-1)d=1;if(i==h-1&d==1)d=-1;i+=h>1?d:0;}for(String s:l)System.out.println(s);}}@Quincunx:import.util.Arraysはもう必要ありません。=)
flawr

9

ルビー、112バイト

o="#{' '*29}
"*h
26.times{|i|o[(h-i%(h<2?1:2*h-2)-1).abs*30+i+(i>17?3:0)]=(i+65).chr}
puts o.gsub('R   ','Ruby')

入力がに格納されることを期待していhます。

これに説明が必要かどうかを教えてください。


非常にマイナーですが、後にスペースを削除できます%
カルビンの趣味14

@ Calvin'sHobbiesハ、構文の強調表示は信用できませんでした:D。後で修正します。
マーティンエンダー14

あなたは置き換えることができputs o...$><<o...
ヨルダン

6

J:75バイト

NB. without IO |:26([:u:65+i.@[)`(($(,|.@}.@}:)@i.)<"1@,.i.@[)`(' '$~,~)}5
2(1!:2)~|.26([:u:65+i.@[)`(($(,|.@}.@}:)@i.)<"1@,.i.@[)`(' '$~,~)}".1!:1[1

すばらしい修正接続詞を使用します。いつものように、IOは見苦しくて不格好で、そこでは詳しく説明しません。コアソリューションには3動詞(名詞修飾動詞(別名、関数)の一種)が必要です。

  • a)アルファベットの生成
  • b)インデックスの生成
  • c)修正するマトリックスを生成する

    x(a bc})y

a)asciiテーブルでの非常に簡単なルックアップ

c)さらに些細なこと

b)興味深いものです。士気は、水平方向のインデックスが0からy-1に始まり、これを26回繰り返すことを想定していることです。例えば。y == 4の場合:

0 1 2 3 2 1 0 1 2 3 2 1 ...

これを実装すると、b)が得られます。

($(,|.@}.@}:)@i.) <"1@,. i.@[)       NB. is equivalent too
(tine0 tine1 tine2)                  NB. a fork with tines defined as
tine0 =: 
  hook0 =: hook0_0 hook0_1           NB. a dyadic hook: x (g h) y -: x g h y
     hook0_0 =: $                    NB. reshape
     hook0_1 =: (hook1_0 hook1_1)@i. NB. do hook1 after making 0-y
       hook1_0=: ,                   NB. append to self
       hook1_1=: |.@}.@}:            NB. rotated version of y after beheading and curtailing
tine2 =: i.@[                  NB. generate 0-x
tine1 =: <"1@,.                NB. glue together coordinates.

そして、ああ、便利な事実:Jの名前は... "J"です。


修正を使用する価値はありますか?3 :'|:(26$1+(i.1=y),}:|i:<:y)|.@{."+u:65+i.26'その解決策のlikeい部分は、特殊なケースの高さ1の8文字であると言う方が簡単に思えますが、これはおそらく少し短くすることができます。
b_jonas 14

提案をありがとう!あなたのものは確かにはるかに短く、修正はおそらく過剰です。それは非常に異なっているので、おそらくあなたはそれを自分で解決策として投稿したいですか?
jpjacobs 14

仕様には「末尾のスペースがない」と書かれており、私のソリューションは末尾のスペースを出力します。
b_jonas

5

R(204)

f=function(x) {
  m=matrix(" ",x,26)
  i=x
  d=ifelse(x==1,0,-1)
  for (j in 1:26) {
    m[i,j]=LETTERS[j]
    if (!((i+d) %in% 1:x)) d=-d
    i=i+d
  }
  for (i in 1:x) cat(m[i,],"\n",sep="")
}

結果

> f(1)
ABCDEFGHIJKLMNOPQRSTUVWXYZ
> f(2)
 B D F H J L N P R T V X Z
A C E G I K M O Q S U W Y 
> f(3)
  C   G   K   O   S   W   
 B D F H J L N P R T V X Z
A   E   I   M   Q   U   Y 
> f(7)
      G           S       
     F H         R T      
    E   I       Q   U     
   D     J     P     V    
  C       K   O       W   
 B         L N         X Z
A           M           Y 

あなたがそこで何をしたかわかる!非常にスマート...
Kroltan

1
+1きちんと!forただし、ステートメントの周囲のスペース(for(i in 1:x)cat(...たとえば)または周囲のスペースを取り除くことができます%in%
plannapus 14

3

Javascript- 248 224 235

z=~~prompt(),y="ABCDEFGHIJKLMNOPQRSTUVWXYZ".split("");y[9]="Javascript";for(w=[],v=0;v<z;v++)w[v]="\n";v--;for(i=0;i<26;i++){for(j=0;j<z;j++)w[j]+=j-v?i-9?" ":"          ":y[i];~~(i/(z-1))%2?v++:v--;}if(z==1)w=y;console.log(w.join(""))

ここに jsfiddleへのリンクがあり、そこでテストできます。
編集:等幅フォントのコンソールログを作成し、input == 1の場合はコンマを削除しました。


提案:1:parseIntとMath.floorは、|0またはのような整数強制操作で変更できます~~。2:を使わずにw配列を直接構築する方が短いsplitfor(w=[],v=0;v<z;v++)w[v]="\n";
edc65 14

...と、そこに出力文が(にconsole.logまたはchar数の何でも、あなたのフィドルに使用し、それの一部)ではありません
edc65

@ edc65ヒントをありがとう。私はここで出力を忘れてしまったので、アラートを追加しましたが、モノスペースのフォントがないため、かなり混oticとして見えます。
izlin 14

@izlin代わりに、文字を保存するを(i==9?" ":" ")使用できます(i^9?" ":" ")
rev 14

1
助けて!誰でも説明できますか?(なぜ<code> v = 0 </ code>が2回あるのですか?)
flawr

3

Perl 119

$s.=/26/?++$r&&$/:$m-1&&$r-abs$_%(2*$m-2)+1-$m?$"x(1+3*/15/):/15/?Perl:(A..Z)[$_]for(0..26)x($m=<>);print$s=~s/\s+$//rg

このプログラムは、入力を受け取りSTDIN、結果をに出力しSTDOUTます。

そしてボーナス-後続のスペースを印刷するが、いくつかの相互作用を追加するため、ルールに反するバージョン:

#!/usr/bin/perl -p
$r=0;$_=join'',map{/26/?++$r&&$/:$m-1&&$r-abs$_%(2*$m-2)+1-$m?$"x(1+3*/15/):/15/?Perl:(A..Z)[$_]}(0..26)x($m=$_)

...および以下のテスト:

1
ABCDEFGHIJKLMNOPerlQRSTUVWXYZ
2
 B D F H J L N Perl R T V X Z
A C E G I K M O    Q S U W Y
4
   D     J     Perl     V
  C E   I K   O    Q   U W
 B   F H   L N      R T   X Z
A     G     M        S     Y
6
     F         Perl         Z
    E G       O    Q       Y
   D   H     N      R     X
  C     I   M        S   W
 B       J L          T V
A         K            U

3

J、67 57 61文字

echo@dtb"1@|.@|:@(26&,$(u:65+i.26)#~1 j.26$(0#~1=]),<:#-&0 2)

機能として使用:

   echo@dtb"1@|.@|:@(26&,$(u:65+i.26)#~1 j.26$(0#~1=]),<:#-&0 2)
   D     J     P     V
  C E   I K   O Q   U W
 B   F H   L N   R T   X Z
A     G     M     S     Y

説明:このソリューションは、他のJソリューションとは異なるアプローチを使用します。のこぎり波0 1 2 3 2 1 0 1 ...を生成する代わりに、連続する文字間の間隔を調べました。例えば、のためのn = 4あなたが上向きにAから行く場合は、文字間の間隔のこのパターンは非常に規則的である、あなたはAとBの間の4つのスペースを見つけ、第二のカラムリーチBにオーバーラップ:用のn = 4パターンは4 4 4 2 2 2 4 4 4 ...

そのため、まずフラット化された(転置された)配列を作成し、次にそれを整形して、正しく見えるように裏返します。出力ルーチンは単純です(少なくともJであるため):dtbは「末尾ブランクを削除する」であり、"1「各行で操作する」と言います。 dtbechoは両方とも標準ライブラリによって提供されます。

ゴルフの手助けをしてくれたZsbánAmbrusに感謝します。


3

メタポスト(207)

numeric h,d,y;h=5;d=-1;y=1;u=5mm;pair p;string s;for x=1upto26:p:=(x,y)*u;s:=char(x+64);if x=13:s:="MetaPost";elseif x>13:p:=(x+2,y)*u;fi;label.rt(s,p);if(y=h)or(y=1):d:=d*-1;fi;if h=1:d:=0;fi;y:=y+d;endfor;

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

こちらで試すことができます。


2

バッシュ(213)(223)

read i
p=0
d=1
printf '\n%.0s' `seq $i`
for l in {A..Z}
do (($p==$i-1))&&((p=$p*-1))
(($i==1))&&p=0
(($p!=0))&&echo -en "\033[s\033[${p#-}A"
[[ "$l" == "B" ]]&&l="Bash"
echo -en $l"\033[s\033[${p#-}B"
((p++))
done

微調整して、213になりました。

オリジナルのものには小さなバグがありました。bashバージョン4.2.37で動作することをテストおよび確認しました。

バグといくつかのヒントを指摘してくれた@manatworkに感謝します。


構文の強調表示を追加して投稿を編集しましたが、コードの一部がコメントとして誤って強調表示されているので、ロールバックしました。なぜ私はそれをロールバックしたのか疑問に思っている場合にこれを言った:)
ProgramFOX 14

@ProgramFOX大丈夫です。とにかくありがとう!
Okw

出力が徐々に低下しているため、どこかに小さなバグがあると思います。(。バッシュ4.3で少なくとも)194文字にサイズを小さくするためにいくつかのマイナーな改良:オミット算術評価で印章、二重引用符で囲まれた文字列内の二重引用符にしようとしないでくださいpastebin.com/zKa3zdwR
manatwork

;少し読みやすくするために、いくつかの代わりに改行を使用できますか?ゴルフのスコアには影響しません
デジタルトラウマ14

2

Haskell – 432バイト(残念ながら...)

これは、純粋に達成するために予想していたよりもはるかに難しいことが判明したため、バイトカウントが非常に大きくなりました。私(または誰か)はもっとうまくやれると確信していますが、これにはあまりにも多くの時間を費やしました。ゴルフバージョンは次のとおりです。

import Data.Matrix
import Data.Vector(toList)
r=repeat
s h=y h$l(take 26(case h of 1->r 1;_->concat$r$[h,h-1..1]++[2..h-1]))['A'..'Z']$matrix h 32(const ' ')<|>matrix h 1(const '\n')
l _[]m=m
l(x:i)(r:e)m=l i e$u m(let z=26-length i in if z<9 then z else z+6)x r
l _ _ m=m
u m c r h=case h of 'H'->t c r"Haskell"m;_->setElem h(r,c)m
t _ _[]m=m
t c r(x:i)m=t(c+1)r i$setElem x(r,c)m
y h m=concat[toList$getRow x m|x<-[1..h]]

ghci実行するputStr $ s IntIntは、コードをロードして、希望する高さの場所を実行します。追加することもできます

import System.Environment
main :: IO ()
main = fmap (s . read . head) getArgs >>= putStr

importテキストファイルのsの下で、でコンパイルghcし、コマンドライン引数として高さを渡します。ゴルフされていないバージョン:

import System.Environment
import Data.Matrix
import Data.Vector (toList)

main :: IO ()
main = fmap (sawtooth . read . head) getArgs >>= putStr

type M = Matrix Char

sawtooth :: Int -> String
sawtooth height = let mat     = matrix height 32 (const ' ') <|> matrix height 1 (const '\n')
                      numbers = take 26 (case height of 1 -> repeat 1
                                                        _ -> concat $ repeat $ [height,height-1..1]++[2..height-1])
                      chars   = ['A'..'Z']
                  in toString height $ makeMatrix numbers chars mat

makeMatrix :: [Int] -> String -> M -> M
makeMatrix []     []     mat = mat
makeMatrix (x:xs) (s:ss) mat = makeMatrix xs ss $ updateMatrix
                                                    mat (let z = 26 - length xs in if z < 9 then z else z + 6) x s
makeMatrix _      _      mat = mat

updateMatrix :: M -> Int -> Int -> Char -> M
updateMatrix mat col row char = case char of 'H' -> insertHaskell col row "Haskell" mat
                                             _   -> setElem char (row, col) mat

insertHaskell :: Int -> Int -> String -> M -> M
insertHaskell _   _   []     mat = mat
insertHaskell col row (x:xs) mat = insertHaskell (col+1) row xs $ setElem x (row, col) mat

toString ::Int -> M -> String
toString height mat = concat [ toList $ getRow x mat | x <- [1..height] ]

(関数のApplicativeインスタンスを使用して)に置き換えconstpure数バイトを節約できると思います。
エソランジングフルーツ

2

C#/ LINQ:

using System;
using System.Linq;

namespace SawtoothAlphabet
{
    class Program
    {
        static void Main(string[] args)
        {
            int N = Int32.Parse(args[0]);   // eg 4
            Console.WriteLine(
                String.Join(Environment.NewLine, Enumerable.Range(0, N).Select(line =>
                    String.Concat(Enumerable.Range(0, 26).Select(i =>
                        line == Math.Abs(i % (2 * (N - 1)) - (N - 1))
                            ? (i == 2) ? "C#" : Char.ConvertFromUtf32(i + 'A')
                            : (i == 2) ? "  " : " ")
            ).TrimEnd())));
        }
    }
}

簡単な説明:Enumerable.Range(0, N).Select(...)各行に対して文字列が生成され、最終的にで単一の文字列に連結されますString.Join(Environment.NewLine, ...)。を使用して26行すべてを循環する各行についてEnumerable.Range(0, 26).Select(...)、ラムダ式の開始時のテストは、i==2「C」のチェック中に文字またはスペースを生成するかどうかを決定し、行に応じて「C#」または2つのスペースに変換します。は、各行String.Concat(...)の結果IEnumerable<char>を文字列に変換してTrimEnd(...)から、後続の空白をきれいに取り除きます。


1

PHP (216)(205)

新しいバージョン:

$b=array_fill(65,26,' ');$b[80]='   ';$b=array_fill(0,$i,$b);for($j=--$i,$x=64;++$x<91;$i||$j=0){$b[$j][$x]=chr($x);$x==80&&$b[$j][$x]='PHP';$j+=($d=$j<($d?$i:1))*2-1;}echo join("\n",array_map('join',$b));

旧版:

$b=array_fill(0,$i,array_fill(0,28,' '));for($j=--$i,$x=-1;++$x<28;$i||$j=0){$q=&$b[$j];$q[$x]=chr($x-($x&16)/8+65);$x==15&&($q[++$x]='H')*$q[++$x]='P';$j+=($d=$j<($d?$i:1))*2-1;}echo join("\n",array_map('join',$b));

変数$ iが高さであることを期待します。


1

C、214 169バイト、末尾スペースなし

役に立つ提案をしてくれた@ edc65と@tolosに感謝します。

#define C ((c-i+n-65)%z&&(c+i+n-67)%z)
n,i,m,c,z;main(){scanf("%d",&n);z=n<2?1:2*n-2;for(;i++<n;){for(m=c=64;c++<90;)m=C?m:c;for(c=64;c++<m;)putchar(C?32:c);puts("");}}

3
それは負けた戦いですが、私は固執します:#include <stdio.h>は、多くの場合、gccやその他のコンパイラーでは必要ありません。とにかく標準で有効なCです。
edc65 14

2
@ edc65:「有効なC」と考えるものに依存します。これは、私の知る限り、有効なK&R Cですが、ANSI / ISO Cは(含ま可変長引数の関数ことを要求scanfしてはprintf)そうでなければ、未定義の動作を得るでしょう、プロトタイプを与えられています。#include <stdio.h>もちろん、両方にプロトタイプを与えるための最短の方法ですscanfprintf
celtschk 14

コードゴルフでは、@ celtschkの有効なK&Rで十分です。また、「多くの場合」(たとえば、putsを使用する場合のみ)は有効なC89です。私が強調したいのは、それがgccの奇妙な動作ではないということです。(とにかく可変個性関数についてのメモのおかげで)
edc65 14

1
グローバルはint型であり、ゼロに初期化されます。int何も返さない場合は、mainの宣言を削除することもできます。、余分な括弧をドロップ置き換えることができる' '32し、if(!C)m=cternarny文で、私はちょうど学んだよう(上記)を交換printf("\n")してputs("")、18文字のため:n,i,m,c,z;main(){;scanf("%d",&n);z=n<2?1:2*n-2;for(;i<n;i++){for(m=c=65;c<91;c++)m=C?m:c;for(c=65;c<=m;c++)printf("%c",C?32:c);puts("");}}

1

Javascript(204185150

h=m=4;d=h>1?-1:0;o=[];for(a=0;a<35;a++){for(r=h;r;r--)o[r]=(o[r]||"")+(r==m?"ABCDEFGHIJavascriptKLMNOPQRSTUVWXYZ"[a]:" ");if(a<9||a>17){m+=d;if(m<2||m==h)d=-d}}console.log(o.join("\n"))

編集

配列と.join( "\ n")を構築しないことで13バイトを節約しました。forループの反転が必要です。次に、Cコーディングの息子の助けを借りて、コードを完全に賢くして、さらに12バイト節約しました。

ロジックの変更を示す読みやすいバージョンを次に示します。

for (row = height; row; row--) {
    rowOfNextActiveLetter = 1;
    direction = height > 1 ? -1 : 0;
    output = "";
    for (a = 0; a < 35; a++) {
        output += (row == rowOfNextActiveLetter ? "ABCDEFGHIJavascriptKLMNOPQRSTUVWXYZ"[a] : "");
        if (a < 9 || a > 17) {
            rowOfNextActiveLetter -= direction;
            if (rowOfNextActiveLetter < 2 || rowOfNextActiveLetter == height)direction = -direction
        }
    }
    console.log(output)
}

ゴルフ(161):

for(r=h;r;r--){m=1;d=h>1?-1:0;o="";for(a=0;a<35;a++){o+=(r==m?"ABCDEFGHIJavascriptKLMNOPQRSTUVWXYZ"[a]:" ");if(a<9||a>17){m-=d;if(m<2||m==h)d=-d}}console.log(o)}

ゴルフと難読化(149):

for(r=h;r;r--,console.log(o))for(m=1,d=h>1?1:0,o="",a=0;a<35;)if(o+=r==m?"ABCDEFGHIJavascriptKLMNOPQRSTUVWXYZ"[a]:" ",a<9|a++>17)d=(m+=d)<2|m==h?-d:d

完全に理解できなくても好きです。とにかくsubstrを削除し、直接インデックスを使用して9文字をカットできます.substr(a,1)=>[a]
edc65 14

あなたは182のためのビット単位の演算子と合体イテレータを使用して、それをさらに絞り込むことができます: h=m=4;d=1<h?-1:0;o=[];for(a=0;35>a;a++){for(r=h;r;r--)o[r]=(o[r]||"")+(r==m?"ABCDEFGHIJavascriptKLMNOPQRSTUVWXYZ"[a]:" ");if(9>a|17<a)if(m+=d,2>m||m==h)d=-d}console.log(o.join("\n"))
WallyWest

おっと、1つのスペースをクリーンアップしすぎた
ジョン・

1

K、60バイト

`0:'{+{x!y}.'+(26#{(!x),|1_!x-1}x;(((x-1)#" "),)'`c$65+!26)}

かなり簡単で、Jソリューションを削ったようです。:)

まず、アルファベットを生成します。

  `c$65+!26
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"

そして適切な長さののこぎり波:

  26#{(!x),|1_!x-1}5
0 1 2 3 4 3 2 1 0 1 2 3 4 3 2 1 0 1 2 3 4 3 2 1 0 1

アルファベットの各文字に先行スペースを埋め込む:

  (((5-1)#" "),)'"ABC"
("    A"
 "    B"
 "    C")

アルファベットと方形波を一緒に圧縮し、各行を回転させます。

  +(0 1 2;("  A";"  B";"  C"))
((0
  "  A")
 (1
  "  B")
 (2
  "  C"))

  {x!y}.'+(0 1 2;("  A";"  B";"  C"))
("  A"
 " B "
 "C  ")

そして、その転置が私たちの答えです。

  +{x!y}.'+(0 1 2;("  A";"  B";"  C"))
("  C"
 " B "
 "A  ")

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


0

C: 142139文字

ひどく長いので、少し短くできると期待しています。

char a[26][27],i,j,p,d;main(n){for(scanf("%d",&n);i<26;d^=!p^p+2>n,p+=d-(d^n>1),i++)for(j=n;j--;a[j][i]=p^j?32:i+65);while(n)puts(a[--n]);}

少し読みやすい:

char a[26][27], i, j, p, d;
main(n) {
    for (
        scanf("%d", &n);
        i < 26;
        d ^= !p ^ p + 2 > n,
        p += d - (d ^ n > 1),
        i++
    )
        for (
            j = n;
            j--;
            a[j][i] = p ^ j
                ? 32
                : i + 65
        );

    while (n)
        puts(a[--n]);
}

編集:「後続スペースなし」ルールを逃しましたが、戻ってきます。


0

Scala、246バイト

def f(h:Int)={val a=Seq.fill(h)(Array.fill(32)(' '));var(r,x,d)=(h-1,0,if(h==1)0 else-1);def p(c:Char){a(r)(x)=c;x+=1};for(c<-'A'to'Z'){p(c);if(c==83)"cala"foreach p;r+=d;if(r==0|r==h-1)d*= -1};for(z<-a)println(new String(z)replaceAll(" +$",""))}

再フォーマットおよびコメント:

def f(h: Int) = {
  val a = Seq.fill(h)(Array.fill(32)(' '));
  // r - row; x - x coordinate, column; d - direction
  var (r, x, d) = (h - 1, 0, if(h==1) 0 else -1); 
  def p(c: Char) { // p for "put the character"
    a(r)(x) = c;
    x += 1
  };
  for(c <- 'A' to 'Z') { 
    p(c);
    if(c == 83)      // 83 == 'S'
      "cala" foreach p;
    r += d;
    if(r == 0 | r == h - 1)     // | is shorter than || 
      d *= -1
  };
  for(z <- a)
    println(new String(z) replaceAll (" +$", ""))  // trimming trailing whitespace
}

結果:

scala> f(4)
   D     J     P         V
  C E   I K   O Q       U W
 B   F H   L N   R     T   X Z
A     G     M     Scala     Y

scala> f(5)
    E       M           U
   D F     L N         T V
  C   G   K   O   Scala   W
 B     H J     P R         X Z
A       I       Q           Y

scala> f(1)
ABCDEFGHIJKLMNOPQRScalaTUVWXYZ

0

パイソン-137

IEGに保存される入力 i=8

l=[""]*h;k=j=0;y=h-1;exec'l[y]+=" "*(j-len(l[y]))+chr(k+65)+"ython"*(k==15);j=len(l[y]);y-=1^k/(h-(h>2))%2*-2;k+=1;'*26;print"\n".join(l)

0

ラケット

きれいな機能バージョンがあります:短縮する提案を歓迎します。

(define (sawtooth n)
  (define (ST i d m lns)
    (if (null? m) 
        lns
        (let* ([v (first m)]
               [spc (make-string (string-length v) #\space)]
               [I (+ i d)])
          (ST I
              (if (or (zero? I) (= (sub1 n) I)) (* d -1) d)
              (rest m)
              (for/list ([ln lns] [j n])
                       (~a ln (if (= i j) v spc)))))))
  (displayln
   (string-join 
    (ST (sub1 n)
        (if (= n 1) 0 -1) 
        (string-split "A B C D E F G H I J K L M N O P Q Racket S T U V W X Y Z")
        (make-list n "\n")))))

出力

> (sawtooth 1)
ABCDEFGHIJKLMNOPQRacketSTUVWXYZ

> (sawtooth 2)
 B D F H J L N P Racket T V X Z 
A C E G I K M O Q      S U W Y 

> (sawtooth 8)
       H                  V     
      G I                U W    
     F   J              T   X   
    E     K            S     Y  
   D       L     Racket       Z 
  C         M   Q               
 B           N P                
A             O  
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.