Зробіть зигзагоподібний візерунок


25

Ваше завдання - взяти один цілий вхід і надрукувати зигзагоподібний зразок за допомогою косої та зворотної косої риски.

  • Ціле введення визначає довжину кожного зигзагу та заг, а також кількість зигів та загів
  • Візерунок завжди починається справа наліво

Випробування

4->
   /
  /
 /
/
\
 \
  \
   \
   /
  /
 /
/
\
 \
  \
   \
2->
 /
/
\
 \
0->
1->
/
8->
       /
      /
     /
    /
   /
  /
 /
/
\
 \
  \
   \
    \
     \
      \
       \
       /
      /
     /
    /
   /
  /
 /
/
\
 \
  \
   \
    \
     \
      \
       \
       /
      /
     /
    /
   /
  /
 /
/
\
 \
  \
   \
    \
     \
      \
       \
       /
      /
     /
    /
   /
  /
 /
/
\
 \
  \
   \
    \
     \
      \
       \

3
Чи можемо ми вивести масив / список рядків для кожного рядка? Чи дозволено навчання або провідні новинки чи пробіли?
Кудлатий

2
Чи добре у провідних пробілів, якщо на малюнок це не впливає?
Емінья

Відповіді:


10

C (gcc) , 108 102 101 98 80 76 72 байт

  • Збережено шість байтів завдяки Кевіну Крейсейну ; видалення дужок і гольфу N-n-1доN+~n
  • Збережено байт, перемістивши Zінкремент в стан циклу
  • Збережено три байти, використовуючи printf("%c\n",...)замість putchar(...)і,puts("")
  • Збережено вісімнадцять (!) Байтів завдяки HatsuPointerKun ; використання printf("%*s",n,"");для друку nпробілів замість використання циклу j;for(j=n;j--;)putchar(32);та комбінування обох printf(...);дзвінків
  • Збережено чотири байти, використовуючи printf("%*c",-~n,...);замістьprintf("%*s%c",n,"",...);
  • Збережено чотири байти завдяки nwellnhof ; переміщення всього всередині однієї петлі замість двох
j;f(k){for(j=0;j<k*k;j++)printf("%*c\n",j/k%2?j%k+1:k-j%k,j/k%2?92:47);}

Спробуйте в Інтернеті!


Z,n,j;f(N){for(Z=0;Z<N;Z++)for(n=N;n--;putchar(Z%2?92:47),puts(""))for(j=Z%2?N+~n:n;j--;)putchar(32);} 102 байти . Зняли фігурні дужки, поклавши все всередину петель; і змінив N-n-1на N+~n.
Кевін Кройсейсен

1
@KevinCruijssen Дякую Збережено ще один байт, замінивши обидва Z%2?...:...і замінивши Z<N;Z++на Z++<N;.
Джонатан Фрех

1
Ви можете зберегти кілька байтів, використовуючи магію printf, як я це зробив у своїй відповіді . Таким чином ви позбудетесь циклу for, який використовується для друку пробілів. Детальніше дивіться відповідь про переповнення стека про ліві прокладки з printf
HatsuPointerKun

@HatsuPointerKun Спасибі; це дійсно короткий спосіб повторити пробіли у C.
Джонатан Фрех

4 байт коротше: i;f(N){for(i=0;i<N*N;i++)printf("%*c\n",i/N%2?i%N+1:N-i%N,i/N%2?92:47);}. Спробуйте в Інтернеті!
nwellnhof

10

Вугілля , 16 10 9 байт

FN«↖Iθ→‖T

Спробуйте в Інтернеті! Посилання на багатослівну версію коду.


це працює (Був InputNumberзламаний і в режимі golfy?)
лише ASCII

@ ASCII Тільки Ні, таким чином, окремі посилання на дану коротку версію та приблизну багатослівну версію.
Ніл

О> _> не дивився, щоб побачити, яке посилання я відкривав
лише для ASCII

@ ASCII only Ну, зараз є лише одне посилання ;-)
Ніл

4

MATL , 17 байт

:"GXy@o?P47}92]*c

Спробуйте в Інтернеті!

Пояснення

:         % Implicit input, n. Push range [1 2 ... n]
"         % For each k in that range
  G       %   Push n again
  Xy      %   Identity matrix of that size
  @       %   Push k
  o?      %   If it's odd
    P     %     Flip the matrix upside down
    47    %     Push 47 (ASCII for '/')
  }       %   Else
    92    %     Push 92 (ASCII for '\')
  ]       %   End
  *       %   Multiply each entry of the matrix by that number
  c       %   Convert to char. Char 0 is shown as space
          % Implicit end. Implicit display

4

C # (.NET Core) , 117 103 101 байт

a=>{for(int z=a+1,e=0;e<a*a;)System.Console.WriteLine(e++/a%2<1?"/".PadLeft(--z):@"\".PadLeft(z++));}

Спробуйте в Інтернеті!


Ви можете зберегти 14 байт так: a=>{var o="";for(int z=a+1,e=0;e<a*a;)o+=(e++/a%2<1?"/".PadLeft(--z):@"\".PadLeft(z++))+"\n";return o;} 103 байти Вам не потрібні всі ці дужки; ви можете комбінувати int; і додайте лише +"\n"один раз.
Кевін Круїссен


Хм, ви можете зберегти ще 2 байти, надрукувавши безпосередньо, замість того, щоб повернути рядок: a=>{for(int z=a+1,e=0;e<a*a;)System.Console.WriteLine(e++/a%2<1?"/".PadLeft(--z):@"\".PadLeft(z++));} 101 байт
Кевін Круїйсен

3

SOGL V0.12 , 13 12 9 байт

╝F{±↔}P}ø

Спробуйте тут!

може бути 8 байт, ╝F{±↔}P}якщо тестовий зразок 0 не був потрібен

Пояснення:

       }   implicitly started loop repeated input times
╝            create a down-right diagonal of the input
 F           get the current looping index, 1-indexed
  {  }       that many times
   ±↔          reverse the diagonal horizontally
      P      print that
        ø  push an empty string - something to implicitly print if the loop wasn't executed


3

Математика, 84 90 байт

(n=#;Grid@Array[If[Abs[n-(s=Mod[#-1,2n])-.5]==#2-.5,If[s<n,"‌​/","\\"],""]&,{n^2,n‌​}])&
  • Дякую Jenny_mathy за -6 байт.

Я поняття не маю, чому \явно темніше /.

enter image description here


2
84 байти(n=#;Grid@Array[If[Abs[n-(s=Mod[#-1,2n])-.5]==#2-.5,If[s<n,"/","\\"],""]&,{n^2,n}])&
J42161217

3

Jq 1,5 , 94 89 байт

["/","\\"][range($n)%2]as$s|range($n)|[(range(if$s=="/"then$n-.-1 else. end)|" "),$s]|add

Пояснення

  ["/","\\"][range($n)%2] as $s                         # for $s= / \ / \ $n times 
| range($n)                                             # for .=0 to $n-1
| [(range(if $s=="/" then $n-.-1 else . end)|" "), $s]  # form list of spaces ending with $s
| add                                                   # concatenate

Виконання зразків

$ jq -Mnr --argjson n 5 '["/","\\"][range($n)%2]as$s|range($n)|[(range(if$s=="/"then$n-.-1 else. end)|" "),$s]|add'
    /
   /
  /
 /
/
\
 \
  \
   \
    \
    /
   /
  /
 /
/
\
 \
  \
   \
    \
    /
   /
  /
 /
/

Спробуйте в Інтернеті!


3

Java 8, 140 134 116 байт

n->{String r="";for(int a=0,b,c;a++<n;)for(b=n;b-->0;r+=a%2>0?"/\n":"\\\n")for(c=b-n+b|-a%2;++c<b;r+=" ");return r;}

-24 байт завдяки @Nevay .

Пояснення:

Спробуйте тут.

n->{                // Method with integer parameter and String return-type
  String r="";      //  Result-String
  for(int a=0,b,c;  //  Index integers
      a++<n;)       //  Loop (1) from 0 to the input (exclusive)
    for(b=n;        //   Reset `b` to the input
        b-->0;      //   Inner loop (2) from the input to 0 (exclusive)
                    //     After every iteration: 
        r+=a%2>0?"/\n":"\\\n") 
                    //      Append either of the slashes + a new-line
      for(c=b-n+b|-a%2;++c<b;r+=" ");
                    //    Append the correct amount of spaces
                    //   End of inner loop (2) (implicit / single-line body)
                    //  End of loop (1) (implicit / single-line body)
  return r;         //  Return the result-String
}                   // End of method

1
Стан найпотаємнішої петлі можна записати у вигляді c-->f*(b-n-~b)(-6 байт).
Невай

1
116 байт:n->{String r="";for(int a=0,b,c;a++<n;)for(b=n;b-->0;r+=a%2>0?"/\n":"\\\n")for(c=b-n+b|-a%2;++c<b;r+=" ");return r;}
Невай

3

Javascript ES8, 83 79 78 76 75 74 71 байт

* скоротив 1 байт за допомогою ES8 завдяки Shaggy

A=(m,i=0)=>i<m*m?`/\\`[x=i/m&1].padStart(x?i%m+1:m-i%m)+`
`+A(m,++i):""

Тестуйте тут


хто б не спричинив моє рішення, ви могли б пояснити, чому? Я щось пропускаю?
DanielIndie

2
Я не є тим, хто виступав проти цього, але я вважаю, що це тому, що функції повинні бути повторюваними, щоб бути дійсними. Ваше можна було легко виправити, iвстановивши параметр за замовчуванням. Кількість байтів теж не враховується.
Емінья

1
Додавання посилання TIO завжди цінується, щоб люди могли легко перевірити ваше рішення.
Емінья

1
@Emigna виправила це (char mud та Link
mud

1
74 байти з деяким ES8. Крім того, для JS ви можете просто використовувати фрагмент стека, а не TIO.
Кудлатий


2

PowerShell , 81 байт

param($a)if($a){1..$a|%{((1..$a|%{" "*--$_+'\'}),($a..1|%{" "*--$_+'/'}))[$_%2]}}

Спробуйте в Інтернеті!

Фу, це некрасиво. Стільки повторених кодів, плюс 7 байт, необхідних для обліку 0спеціального випадку. Пропозиції з гольфу вітаються.


2

Піт, 17 байт

js<*_+RV"\/"_B*L;

Спробуйте в Інтернеті: Демонстрація

Пояснення:

js<*_+RV"\/"_B*L;QQQ   implicit Qs at the end
              *L;Q     list with ["", " ", "  ", ..., " "*(input-1)]
            _B         bifurcate with reverse: [["" to "   "], ["   " to ""]]
     +RV"\/"           append to each one either "\" or "/": 
                       [["\", to "   \"], ["   /" to "/"]]
    _                  reverse
   *              Q    repeat input times
  <                Q   but only take the first input many
 s                     flatten the list of lists
j                      print on each line

2

Пітон 3: 90 байт 82 байт

lambda n:"\n".join(" "*(abs(i%(n*2)-n+i//n%2)-1)+"/\\"[i//n%2]for i in range(n*n))

Дякуємо @Jonathan Frech за те, що він вказав, що друк не потрібен і що перший зигзаг був неправильним


] for-> ]for.
Джонатан Фрех

Вам не потрібна print(...)функція, що повертає рядок, буде дійсною. Крім того, я думаю, що ваш початковий зіг орієнтований неправильно (\ а не /).
Джонатан Фрех

@JonathanFrech Дякую! Я змінив його
Bassintag

1
(abs(...)-1)-> ~-abs(...).
Джонатан Фрех

2

05AB1E , 17 16 байт

F<„/\Nèú.sNƒR}»,

Спробуйте в Інтернеті!

Пояснення

F                  # for N in [0 ... input-1] do
  „/\              # push the string "/\"
     Nè            # cyclically index into this string with N
 <     ú           # prepend input-1 spaces to this string
        .s         # get suffixes
          NƒR}     # reverse the list of suffixes input+1 times
              »,   # join on newline and print

Найкраща поточна спроба використання полотна:

F„/\Nè©53NèΛ2®ð«4Λ



2

Діалог APL , 39 36 35 34 байт

{↑((,⍵ ⍵⍴(⌽,⊢)⍳⍵)/¨' '),¨⍵/⍵⍴'/\'}

Спробуйте в Інтернеті!

1 байт збережено завдяки Zacharý


Заграв, побив мене на один байт. Ви можете ⎕IOбути 0, а потім видалити ¯1+.
Zacharý

@ Zacharý Я ось-ось збирався це зробити: p
dzaima

О, ще одне: (⌽,⊢)⍳⍵замість(⌽⍳⍵),⍳⍵
Zacharý

@ Zacharý Так, я ще не зрозумію прихильності, мовчазності та речей, які випливають із цим: /
dzaima

Не хвилюйтесь, я не повністю розумію, як працюють також поїзди / вилки / що завгодно, як їх називають.
Zacharý



1

Excel VBA, 84 83 байт

Анонімна функція негайного вікна VBE, яка приймає вхід із діапазону [A1]та виводить у безпосереднє вікно VBE

For i=1To[A1]:For j=1To[A1]:?IIf(i mod 2,Space([A1]-j)&"/",Space(j-1)&"\"):Next j,i





Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.