Нарисуйте пилообразный алфавит


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 всегда начинается внизу слева.
  • Ввод может быть через стандартный ввод или вызов функции или аналогичный. Вывод на стандартный вывод.
  • Вход выше 26не должен работать.
  • Нет пробелов.

9
Разрешены ли языки программирования с однобуквенными именами? (C, J, K и т. Д.)
Исаак

@isaacg Конечно. Я полагаю, это может быть проще в них.
Увлечения Кэлвина

1
Можно ли ожидать, что ввод будет храниться в переменной?
Мартин Эндер

@ MartinBüttner Да, все в порядке.
Увлечения Кельвина,

13
Кстати, это не пилообразная волна, это треугольная волна: P
qwr

Ответы:


14

если n содержит высоту:

E + ESC коды: 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);}

С: 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
Мартин Эндер

Могу ли я попросить инструкции по составлению? ccвыдает ошибку «<bebe.c: 1: 17: error: 'n' undeclared (первое использование в этой функции)».
manatwork

2
ну, это намного хуже, чем кажется. во-первых, второй содержит конечные пробелы, во-вторых, они оба полагаются на то, что nэто глобальная переменная, для которой установлено число по вашему выбору (как ранее спрашивал Мартин).
bebe

О, так что я должен предоставить все, что могу. Смешно. Все еще впечатлен.
Манатворк

19

С, 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 с несколькими предупреждениями. Новые строки не включены в число символов.

122 символа, если вход уже сохранен в n.

Благодаря user2992539 , Толосы и edc65 для улучшения.


3
Вы можете использовать puts("")вместо printf("\n").
Сомниум

2
Сохранить 4 символа p-=(c-n+r)%m*((c-n-r)%m)?0:printf("%*c",p,c+65);вместоif((c-...

1
Извините за предыдущий (удаленный) комментарий. Я ошибся. Игра со знаками и злоупотребление тем фактом, что первый аргумент main равен 1, если нет параметров: 134n,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); }
edc65

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,16к For(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
    

    Этот работает хорошо, с двумя незначительными причудами. Высота все еще проблема, хотя ширина не. Однако я не пробел буквы, поэтому в некоторых случаях (когда буква начинает подниматься или опускаться от пилообразного), буквы могут быть отрублены их преемниками. Чтобы он работал независимо от терминала, уберите галочку с верхней границы ( R<7 or). Затем следует график:

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


Теперь я должен перенести это на свой графический калькулятор
Лиам Макинрой

Быстрый комментарий: вместо 0→Fвас можно сделать, Delvar Fчто экономит 1 байт после токенизации. Кроме того, я уверен, что вы можете факторизовать вывод / текст ближе к концу благодаря встроенному логическому условию теста для координаты, а для C+7→C, запишите его в кратком
выражении

11

Чистый 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

Редактировать Исправление ошибки, некоторое изменение порядка и другой способ управления высотой == 1
Более того, оно изменено на функцию, так как это разрешено OP, поэтому не требуется подсказка () для ввода

Никаких изменений в общем алгоритме, который, вероятно, НЕ является лучшим для этой задачи

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

ЯВА (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;. :-(
Джастин

Но вы можете улучшить свой код: исключить String x="ABC...Z";и заменить for(char c...заголовок цикла на for (char c=65;++c<91;){, я люблю символы в Java =)
flawr

Далее вы можете заменить c=='J'на c==74, экономит еще два байта.
flawr

2
Я уверен, что вы можете сделать еще лучше, если сократите if, если будете использовать некоторые XOR для этих операторов if, но здесь моя улучшенная версия: (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.

Дайте мне знать, если это нужно уточнить.


Очень незначительный, но вы можете удалить пространство после %.
Увлечения Кельвина,

@ Calvin'sHobbies Ха, я не доверял своей подсветке синтаксиса: D. Исправлю это позже.
Мартин Эндер

Вы можете заменить 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

Используя замечательное соединение Amend . Как обычно, IO уродлив и неуклюж, не вдаваясь в детали. Основное решение занимает 3 герунда (своего рода существительный глагол (aka. Function)):

  • а) создание алфавита
  • б) генерация индексов
  • c) создание матрицы для внесения поправок в

    x (a bc}) y

а) довольно тривиальный поиск в таблице ascii

в) еще тривиальнее

б) интересный. Мораль такова, что горизонтальные индексы должны начинаться с 0, переходить в y-1 и обратно, повторяя это 26 раз. Например. для y == 4:

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

Реализация этого дает для б):

($(,|.@}.@}:)@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'Уродливой части в этом решении являются 8 символов только для особой высоты 1, но это, вероятно, можно немного сократить.
b_jonas

Спасибо за предложение! Ваш действительно намного короче, и поправка, вероятно, излишняя. Так как это так по-другому, может быть, вы захотите опубликовать это как решение самостоятельно?
jpjacobs

В спецификации написано "нет пробелов", а мое решение печатает пробелы.
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 

Я вижу что ты тут делал! Очень умный ...
Кролтан

1
+1 аккуратно! Вы можете избавиться от пробелов вокруг ваших forутверждений, хотя ( for(i in 1:x)cat(...например) или вокруг %in%.
plannapus

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 напрямую, без split. for(w=[],v=0;v<z;v++)w[v]="\n";
edc65

... и нет оператора вывода (console.log или что-то еще, что вы используете в скрипте, это часть счетчика символов)
edc65

@ edc65 Спасибо за советы. Вы были правы, я забыл вывод, поэтому я добавил предупреждение, но монофонический шрифт отсутствует, поэтому он выглядит довольно хаотично.
Излин

@izlin Вместо того, чтобы (i==9?" ":" ")вы могли использовать (i^9?" ":" "), который сохраняет символ.
Рев

1
ПОМОГИТЕ! кто-нибудь может объяснить? (Почему дважды <code> v = 0 </ code>?)
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 ... я посмотрел на расстояние между последовательными буквами. Например, при п = 4 , если вы идете от А вверх, плотно прилегать к второй колонке и достичь B, то вы найдете четыре пробела между A и B. Эта схема растягивания между буквами очень регулярно: для п = 4 картина 4 4 4 2 2 2 4 4 4 ... .

Таким образом, идея состоит в том, чтобы сначала построить уплощенный (и транспонированный) массив, а затем изменить его и перевернуть так, чтобы он выглядел правильно. Процедура вывода проста (по крайней мере, для J): dtb означает «удалить конечные пробелы» и "1говорит «работать с каждой строкой». dtb и echo предоставляются стандартной библиотекой.

Спасибо Zsbán Ambrus за помощь в игре в гольф.


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

@ProgramFOX Все в порядке. В любом случае, спасибо!
Ok

Я думаю, что где-то есть небольшая ошибка, поскольку выход медленно снижается. (По крайней мере, в Bash 4.3.) Некоторые незначительные улучшения для уменьшения размера до 194 символов: пропустите символ в арифметической оценке, не пытайтесь
заключить

Можете ли вы использовать новые строки вместо некоторых, ;чтобы сделать их чуть более читабельными? Это не повлияет на ваш счет в гольфе
Digital Trauma

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 Intтам, где Intвы хотите нужную высоту. Вы также можете добавить

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

под imports в текстовом файле скомпилируйте его 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] ]

Я полагаю, что вы можете заменить constна pure(используя экземпляр Applicative для функций), чтобы сохранить несколько байтов.
Esolanging Fruit

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 #» или в два пробела в зависимости от строки , В 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

2
@ edc65: Зависит от того, что вы считаете «действительным C». Это допустимый AFAIK K & R C, но ANSI / ISO C требует, чтобы функции с переменными координатами (включая scanfи printf) были предоставлены прототипами, в противном случае вы получите неопределенное поведение. #include <stdio.h>Это, конечно, самый короткий способ дать прототип обоим scanfи printf.
celtschk

@celtschk действительный K & R мне достаточно в коде гольф. И «во многих случаях» (например, при использовании «пут») действительно C89. Я хочу подчеркнуть, что это не странное поведение gcc. (Во всяком случае, спасибо за заметку о функциях с переменным значением)
edc65

1
Глобальные типы имеют тип int и инициализируются нулем. Также можно оставить intобъявление для main, если вы ничего не возвращаете. Может упасть дополнительные скобки, заменить ' 'с 32и if(!C)m=cс ternarny заявление, и , как я только что узнал (выше) заменить 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 ( 204 185 150)

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

РЕДАКТИРОВАТЬ

Сохранено 13 байт, не создавая массив и .join ("\ n"). Требуется перевернуть петли. Затем, с помощью сына C coding, сделал код слишком умным, чтобы сохранить еще 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

Мне нравится это, даже если я не понимаю это полностью. Но в любом случае вы можете сократить 9 символов, удалив substr и используя прямой индекс .substr(a,1)=>[a]
edc65

Вы можете сузить его, используя побитовые операторы и объединяющие итераторы для 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

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

Попробуйте это здесь, в порядке .


0

C: 142 139 символов

Ужасно долго, я ожидаю, что смогу немного сократить его:

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

Python - 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  
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.