Помогите моей маниакальной жене украсить нашу елку

36

Моя жена очень, скажем так, особенная, когда дело доходит до украшения нашей елки. Давайте напишем ей код, который поможет ей в это трудное время.

вход

Учитывая вход 2 < n < 10высота дерева и 0 < k < nразличное количество украшений.

задача

Украсьте дерево, начиная с 1и увеличивая, kпока мы обертываем орнаменты вокруг дерева. Если мы дойдем kи у нас будет больше украшений, тогда начнем с 1.

Ничего страшного, если на дереве не одинаковое количество каждого орнамента, если рисунок удовлетворен.

Орнаменты должны появляться над каждой ветвью, ^кроме верхнего ряда.

Дерево структурируется, начиная с одной ветви, затем на следующем уровне + 1 ветка с пробелом между ними, смещенная сверху, как:

 ^
^ ^

Для третьей строки вы бы добавили еще одну ветвь и разложили их снова так, чтобы ни одна ветвь не находилась в том же столбце (если вы думаете о ней как о сетке).

  ^
 ^ ^
^ ^ ^

Выход

Выведите свое украшенное дерево.

Примеры

1.

n = 3, k = 2

  ^      //Height is 3
 ^ ^
^ ^ ^

Теперь мы украшаем каждую ветку, начиная с 1 и увеличивая до k:

  ^
 1 2
 ^ ^
1 2 1
^ ^ ^

2.

n = 6, k = 5

     ^    //Non-Decorated
    ^ ^
   ^ ^ ^
  ^ ^ ^ ^
 ^ ^ ^ ^ ^
^ ^ ^ ^ ^ ^

     ^    //Decorated
    1 2
    ^ ^
   3 4 5
   ^ ^ ^
  1 2 3 4
  ^ ^ ^ ^
 5 1 2 3 4
 ^ ^ ^ ^ ^
5 1 2 3 4 5
^ ^ ^ ^ ^ ^

3.

n = 5, k = 1

    ^
   ^ ^
  ^ ^ ^
 ^ ^ ^ ^
^ ^ ^ ^ ^

    ^
   1 1
   ^ ^
  1 1 1
  ^ ^ ^
 1 1 1 1
 ^ ^ ^ ^
1 1 1 1 1
^ ^ ^ ^ ^

Это поэтому выигрывает самый короткий код! Удачи и удачи!

jacksonecac
источник
пробелы после каждой строки приемлемы?
Мукул Кумар
1
@MukulKumar нет Это должно поддерживать структуру выше.
jacksonecac
Можем ли мы предположить, что k меньше 10? Или как выровнять числа?
Луис Мендо
2
@LuisMendo Да, предположим, что <10 баллов
jacksonecac

Ответы:

47

C # 226 221 байт

Сохранено 5 байт благодаря @Mukul Kumar и @aloisdg

Golfed:

string C(int n,int k){string o="",x;int j=1,i=1,m;for(;i<=n;i++){o+=string.Concat(Enumerable.Repeat("^ ",i)).PadLeft(n+i)+"\n";m=0;x="";if(i<n){while(m<i+1){if(j>k)j=1;x+=j+++" ";m++;}o+=x.PadLeft(n+i+1)+"\n";}}return o;}

Ungolfed:

public string C(int n, int k, WifeMode wifeMode = WifeMode.Maniacal)
{
  string o = "",x;
  int j = 1,i=1,m;

  for (; i <= n; i++)
  {
    o += string.Concat(Enumerable.Repeat("^ ", i)).PadLeft(n+i) + "\n";

    m = 0;
    x = "";

    if (i < n)
    {
      while (m < i + 1)
      {
        if (j > k) j = 1;
        x += j++ + " ";
        m++;
      }

      o += x.PadLeft(n + i + 1) + "\n";
    }
  }

  return o;
}

Тестирование:

Console.Write(new ChristmasTreeDecorating().C(20, 9));

                   ^ 
                  1 2 
                  ^ ^ 
                 3 4 5 
                 ^ ^ ^ 
                6 7 8 9 
                ^ ^ ^ ^ 
               1 2 3 4 5 
               ^ ^ ^ ^ ^ 
              6 7 8 9 1 2 
              ^ ^ ^ ^ ^ ^ 
             3 4 5 6 7 8 9 
             ^ ^ ^ ^ ^ ^ ^ 
            1 2 3 4 5 6 7 8 
            ^ ^ ^ ^ ^ ^ ^ ^ 
           9 1 2 3 4 5 6 7 8 
           ^ ^ ^ ^ ^ ^ ^ ^ ^ 
          9 1 2 3 4 5 6 7 8 9 
          ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
         1 2 3 4 5 6 7 8 9 1 2 
         ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
        3 4 5 6 7 8 9 1 2 3 4 5 
        ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
       6 7 8 9 1 2 3 4 5 6 7 8 9 
       ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
      1 2 3 4 5 6 7 8 9 1 2 3 4 5 
      ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
     6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 
     ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
    3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 
    ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
   1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 
   ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
  9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 
  ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 
 ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 
^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^

Edit: я была игра кастинг , intчтобы ConsoleColor... Это сезон :)

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

MerryChristmas.gif

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

Пит Арден
источник
3
Вы можете дать i=1в объявлении int и удалить его из forцикла ...
Mukul Kumar
1
Вы можете заменить "\ r \ n" на "\ n". Он будет хорошо работать с ядром и моно.
Aloisdg говорит восстановить Monica
8
Рад видеть C#ответ, получая любовь.
Майкл МакГриф
@aloisdg Спасибо :)
Пит Арден
1
@jacksonecac Рад, что тебе понравилось. Не удержался, как только идея пришла мне в голову :)
Пит Арден,
14

05AB1E ,29 27 24 байта

Сэкономили три байта благодаря Аднану!

>GN„^ ×NÝNLO<+²%>ðý}\».c

>G                       For N in [1, ..., input[0]]
  N„^ ×                  Push a string of "^ " N times
       NÝ                Push [0, ..., N]
         NLO<            Compute the decoration offset, sum([1, ..., N])-1
             +           Add the offset value to each array cell
              ²%         Modulo input[1]
                >        Add 1 so that it is in range [1, k] instead of [0, k-1]
                 ðý      Join with spaces, now we have a string with the full decoration for the current layer
                   }     End for
                    \    Remove the last decoration
                     »   Join everything with newlines
                      .c Center all and implicitly display

Попробуйте онлайн!

Osable
источник
2
Я думаю, что вы можете заменить NN>*;на NLO.
Аднан
Конечно! Это забавно, потому что я фактически использовал N*(N+1)/2намеренно, чтобы получить сумму последовательных целых чисел, начиная с 1, но я полностью забыл, что в 05AB1E есть встроенные модули для этого. Благодарность!
Osable
2
Кроме того, вам нужна ïчасть сейчас: р?
Аднан
1
Я так не думаю ^^.
Osable
12

JavaScript (ES6), 97 байт

Кажется, что ваша жена действительно маниакальна, так что это не включает ни начальную или конечную новую строку, ни начальную или конечную пробел. :-)

f=(n,k,x,s=`^
`)=>n--?(p=' '.repeat(n)+s,x?p.replace(/\^/g,_=>x++%k+1)+p:p)+f(n,k,x||k,'^ '+s):''

демонстрация

Arnauld
источник
8

C ++ 214 - 13 - 3 - 1 -1 - 10 = 186 байт

golfed

#define s std::cout<<
int f(int n,int k){int N=++n,K=0,i=0,I;for(;i<n;i++,N--){for(I=N;I--;)s' ';for(I=0;I++<i&&i-1;)s' '<<(K++%k)+1;s'\n';for(I=N;I--;)s' ';for(I=0;I++<i;)s" ^";s'\n';}}  

Спасибо @ cyoce за сохранение 1 байта.
Спасибо @ Конора для измельчения ее до 186!

Ungolfed + копировать и компилировать

#include<iostream>
#include<conio.h>

#define s(a) std::cout<<a;

int main()
{
    int n,N,k,K=0,i,I;
    std::cin>>n>>k;
    N=++n;
    for(i=0;i<n;i++,N--)
    {
        for(I=N;I--;)

            s(' ')

        for(I=0;I<i&&i-1;I++)

            s(' '<<(K++%k)+1)

        s('\n')

        for(I=N;I;I--)

            s(' ')

        for(I=0;I<i;I++)

            s(" ^")

        s('\n')

    }
    getch();//or any func to pause the console
}  
Мукул Кумар
источник
наконец, <200 ...
Мукул Кумар
1
Вы можете удалить пространство после #define s(a)?
Cyoce
@ Кайос, спасибо! Я не знал об этом!!!
Мукул Кумар
2
186 байтов путем изменения определения #define s std::cout<<и внесения соответствующих корректировок.
Конор О'Брайен
Вааааааа ... это приятно .. никогда не приходило мне в голову: p
Mukul Kumar
3

Python 2, 133 байта

n,k=input()
d=-1
j=' '.join
for i in range(1,n+1):s=' '*(n-i);print(['',s+j(`x%k+1`for x in range(d,d+i))+'\n'][i>1]+s+j('^'*i));d+=i
TFeld
источник
2

Clojure, 223 байта

Мой первый опыт игры в гольф с Clojure:

(let[r repeat](defn d[n k](apply str(concat(r(dec n)\ )"^\n"(flatten(for[i(range 2(inc n))m[nil true]](concat(r(- n i)\ )(butlast(interleave(if m(r\^)(rest(iterate #(inc(mod % k))(dec(/(* i(dec i))2)))))(r i\ )))"\n")))))))

При вызове как (println (str "\n" (d 6 5)))новая строка делает его лучше на REPL:

     ^
    1 2
    ^ ^
   3 4 5
   ^ ^ ^
  1 2 3 4
  ^ ^ ^ ^
 5 1 2 3 4
 ^ ^ ^ ^ ^
5 1 2 3 4 5
^ ^ ^ ^ ^ ^

Un-golfed:

(defn tree-row [n k index mode]
  (concat
    (repeat (- n index) \ ) ; Left padding
    (butlast ; Removing trailing space
      (interleave
        ; Either printing carets or numbers...
        (if mode
          (repeat \^)
          ; Using "rest" as the iteration starts from a large value
          ; from which the modulo has not been calculated yet.
          (rest (iterate #(inc (mod % k)) (dec (/ (* index (dec index)) 2)))))
        ; ...and interleaved with spaces
        (repeat index \ )))
    "\n"))

(defn decorate [n k]
  (apply str (concat
               (repeat (dec n) \ ) "^\n"
               (flatten (for [index (range 2 (inc n)) mode [nil true]]
                          (tree-row n k index mode))))))

У меня были некоторые проблемы с отложенными последовательностями и вложенными списками, но я смог сохранить некоторые символы, не повторяя repeat;) и используя \^символы вместо "^"строк. Я также мог бы оставить на удивление много мест.

NikoNyrh
источник
Хороший первый ответ, добро пожаловать на сайт!
DJMcMayhem
1

Ruby 107 байтов

t=->(n,k){d=[*1..k]*n*n;o=0;(1..n).each{|b|s=' '*(n-b);b>1&&(puts(s+d[o,b].join(' '));o+=b);puts s+'^ '*b}}

Называется так

t.call(5,4)

Выход:

    ^
   1 2
   ^ ^
  3 4 1
  ^ ^ ^
 2 3 4 1
 ^ ^ ^ ^
2 3 4 1 2
^ ^ ^ ^ ^
Нил Слэйтер
источник
1

C 170 байт

i=0;d,j,l;t(n,k){char s[20],r[20];d=k-2;l=n;for(;i++<n;){for(j=0;j<l;++j)s[j]=r[j]=32;for(j=n-i;j<l;j+=2){s[j]=94;r[j]=(++d%k)+49;}s[l]=r[l++]=0;if(i-1)puts(r);puts(s);}}

Звоните с:

int main()
{
   t(5,4);
}

В качестве бонуса, вот 4-битная бинарная версия:

m=0;b(n,k){char*a="000100100011010001010110011110001001";char s[20],r[20];d=k*4-2;l=n;for(;m++<n;){for(j=0;j<l;++j)s[j]=r[j]=32;for(j=n-m;j<l;j+=2){s[j]=94;r[j]=a[++d%(k*4)];}s[l]=r[l++]=0;if(m-1)puts(r);puts(s);}}
Steadybox
источник