Zrób mi więcej!

19

Zrób mi więcej ! Mówię wam o szerokości, ilości krakersa grahamu, ilości czekolady i ilości pianki. Przykład:

Wejście:

Szerokość: 10 Graham: 3 Czekolada: 2 Zefir: 1.

Wynik:

GGGGGGGGGG
GGGGGGGGGG
GGGGGGGGGG
CCCCCCCCCC
CCCCCCCCCC
MMMMMMMMMM
GGGGGGGGGG
GGGGGGGGGG
GGGGGGGGGG

Czy to takie proste? Um ... tak.

Zauważ, że dane wejściowe powinny stanowić listę argumentów funkcji lub programu, a nie ciąg znaków. Możesz wybrać najpierw szerokość, potem Graham, ale każde zamówienie jest w porządku.

Pełne przypadki testowe, jeśli jesteś zainteresowany.

Fragment kodu (do testowania itp.)

Ma to na celu przetestowanie wyjścia.

var smore = function(width, graham, chocolate, marshmallow){
	return ("G".repeat(width) + "\n").repeat(graham) + 
	("C".repeat(width) + "\n").repeat(chocolate) + 
	("M".repeat(width) + "\n").repeat(marshmallow) + 
	("G".repeat(width) + "\n").repeat(graham);
};
Snippetify(smore);
<script src="https://programmer5000.com/snippetify.min.js"></script>
Width: <input type = "number">
Graham: <input type = "number">
Chocolate: <input type = "number">
Marshmallow: <input type = "number">
<button>Try it out!</button>
<pre data-output></pre>

Uwagi:

  • Możesz dodać końcowy znak nowej linii na końcu ostatniego wiersza. Możesz także użyć \zamiast nowej linii.
  • To jest .
  • Jakieś pytania? Komentarz poniżej:
programmer5000
źródło
21
Zredagowałem link Let Me Google That For You. To naprawdę nie było śmieszne.
Level River St
1
@FelipeNardiBatista tak.
programista
1
Niektóre odpowiedzi zakładają elastyczną kolejność wprowadzania i format (jak zwykle w PPCG), ale wyzwanie wydaje się wymagać określonej kolejności i wykluczenia ciągów (nie jestem pewien, co to oznacza). Możesz wyjaśnić?
Luis Mendo
2
Dzięki za wytłumaczenie. Powinieneś przeredagować zdanie, wejście powinno być listą argumentów funkcji lub programu, a nie ciągiem znaków, przy czym pierwszym jest szerokość, potem Graham itp . Osobiście powiedziałbym coś takiego: „Format wejściowy jest elastyczny jak zwykle”
Luis Mendo
4
@ programmer5000, ale dlaczego? Jeśli ocenili to negatywnie, jest to 90% prawdopodobne, ponieważ uważają, że jest to nudne i trywialne wyzwanie. Co więcej, niegrzeczne jest mówienie ludziom, aby tłumaczyli lub wycofywali się. Mają prawo do głosowania bez komentarza.
Rɪᴋᴇʀ

Odpowiedzi:

2

Galaretka , 11 bajtów

ṁ4“GCMG”x×Y

Wypróbuj online!

Jak to działa

ṁ4“GCMG”x×Y  Main link. Left argument: g, c, m. Right argument: w

ṁ4           Mold 4; repeat g, c, m until length 4 is reached. Yields [g, c, m, g].
  “GCMG”x    Repeat 'G' g times, then 'C' c times, then 'M' m times, and finally
             'G' g times. This yields a string.
         ×   Multiply each character w times. This is essentially a bug, but
             Jelly's × behaves like Python's * (and vectorizes), so it can be
             abused for character repetition.
          Y  Join, separating by linefeeds.
Dennis
źródło
13

Python 2 , 73 48 bajtów

lambda w,g,c,m:zip(*['G'*g+'C'*c+'M'*m+'G'*g]*w)

Wypróbuj online!

Tworzy transponowaną wersję odpowiedzi, a następnie transponuje ją do właściwego formatu za pomocą zip(*l)

Felipe Nardi Batista
źródło
8

05AB1E , 21 19 19 bajtów

"GCMG"S×|D«‚øvy`.D»

Wypróbuj online!

-2 dzięki mojemu przeoczeniu i Emignie.

"GCMG"S×            # Push GCMG, separate, duplicate n times.
        |D«         # Push rest of inputs, doubled.
           ‚ø       # Wrap GCMG array and input array, then zip them into pairs.
             vy`.D» # For each pair, print n of G/C/M/G.

(Zobacz odpowiedź Emigny, lepiej: /codegolf//a/116787/59376 )

Urna Magicznej Ośmiornicy
źródło
1
Wygląda na to, że przypadkowo tam zostawiłeś ©.
Emigna
1
Można również wymienić ¬¸się Djako dodatkowe elementy zostały utracone podczas zip.
Emigna
@Emigna Zarówno podoba mi się, jak i nienawidzę tej funkcjonalności.
Magic Octopus Urn
Tak, często jest to bardzo denerwujące, ale od czasu do czasu (tak jak teraz) staje się przydatne :)
Emigna
8

JavaScript (ES6), 71 bajtów

(W,G,C,M)=>[...'GCMG'].map(X=>`${X.repeat(W)}
`.repeat(eval(X))).join``

Woohoo, pokonaj 3 inne odpowiedzi JavaScript!

darrylyeo
źródło
Fajnie, bardzo fajnie - dostaje mój głos.
Kudłaty
7

MATL , 17 bajtów

'GCMG'iK:)Y"!liX"

Format wejściowy to: pierwsze wejście [G, C, M], drugie wejście W.

Wypróbuj online!

Objaśnienie z przykładem

Rozważ dane wejściowe [3 2 1] i 10.

'GCMG' % Push this string
       % STACK: 'GCMG'
i      % Take first input: array of three numbers
       % STACK: 'GCMG', [3 2 1]
K:     % Push [1 2 3 4]
       % STACK: 'GCMG', [3 2 1], [1 2 3 4]
)      % Index (modular, 1-based). This repeats the first entry of the input array
       % STACK: 'GCMG', [3 2 1 3]
Y"     % Run-length decoding
       % STACK: 'GGGCCMGGG'
!      % Transpose. Gives a column vector of chars
       % STACK: ['G'; 'G'; 'G'; 'C'; 'C'; 'M'; 'G'; 'G'; 'G']
l      % Push 1
       % STACK: ['G'; 'G'; 'G'; 'C'; 'C'; 'M'; 'G'; 'G'; 'G'], 1
i      % Take second input: number
       % STACK: ['G'; 'G'; 'G'; 'C'; 'C'; 'M'; 'G'; 'G'; 'G'], 1, 10
X"     % Repeat the specified numbers of times along first and second dimensions
       % STACK: ['GGGGGGGGGG';'GGGGGGGGGG';'GGGGGGGGGG';'CCCCCCCCCC';...;'GGGGGGGGGG']
       % Implicitly display
Luis Mendo
źródło
7

C # , 204 bajty


Grał w golfa

(w,g,c,m)=>{string G="\n".PadLeft(++w,'G'),C="\n".PadLeft(w,'C'),M="\n".PadLeft(w,'M'),o="".PadLeft(g,'G');o+="".PadLeft(m,'M')+"".PadLeft(c,'C')+o;return o.Replace("G",G).Replace("C",C).Replace("M",M);};

Nie golfił

( w, g, c, m ) => {
   string
      G = "\n".PadLeft( ++w, 'G' ),
      C = "\n".PadLeft( w, 'C' ),
      M = "\n".PadLeft( w, 'M' ),
      o = "".PadLeft( g, 'G' );

   o +=
      "".PadLeft( m, 'M' ) +
      "".PadLeft( c, 'C' ) +
      o;

   return o
      .Replace( "G", G )
      .Replace( "C", C )
      .Replace( "M", M );
};

Nieczytelny czytelny

// Function with 4 parameters
//   w : Width
//   g : Graham
//   c : Chocolate
//   m : Marshmallow
( w, g, c, m ) => {

   // Initialization of vars with the contents
   //    of each line, with a new line at the end
   string
      G = "\n".PadLeft( ++w, 'G' ),
      C = "\n".PadLeft( w, 'C' ),
      M = "\n".PadLeft( w, 'M' ),

      // Trick to reduce the byte count
      //   Initialize the output with n 'G's
      o = "".PadLeft( g, 'G' );

   // Add again n 'M's and n 'C's
   //   Append the 'G's at the end.
   o +=
      "".PadLeft( m, 'M' ) +
      "".PadLeft( c, 'C' ) +
      o;

   // Replce every instance of 'G'/'C'/'M'
   //    with the full line
   return o
      .Replace( "G", G )
      .Replace( "C", C )
      .Replace( "M", M );
};

Pełny kod

using System;
using System.Collections.Generic;

namespace Namespace {
   class Program {
      static void Main( String[] args ) {
         Func<Int32, Int32, Int32, Int32, String> f = ( w, g, c, m ) => {
            string
               G = "\n".PadLeft( ++w, 'G' ),
               C = "\n".PadLeft( w, 'C' ),
               M = "\n".PadLeft( w, 'M' ),
               o = "".PadLeft( g, 'G' );

            o +=
               "".PadLeft( m, 'M' ) +
               "".PadLeft( c, 'C' ) +
               o;

            return o
               .Replace( "G", G )
               .Replace( "C", C )
               .Replace( "M", M );
         };

         List<Tuple<Int32, Int32, Int32, Int32>>
            testCases = new List<Tuple<Int32, Int32, Int32, Int32>>() {
               new Tuple<Int32, Int32, Int32, Int32>( 1, 1, 1, 1 ),
               new Tuple<Int32, Int32, Int32, Int32>( 1, 1, 1, 2 ),
               new Tuple<Int32, Int32, Int32, Int32>( 1, 1, 2, 1 ),
               //
               // ...
               //
               // The link above contains the code ready to run
               //    and with every test from the pastebin link
               //
               // Yes, it contains 342 tests ready to run.
               //
               // I can barely fit every test on a 1080p screen...
               //    ... and there's 6 tests per line... Jebus...
               //
            };

         foreach( var testCase in testCases ) {
            Console.WriteLine( $"Input:\nWidth: {testCase.Item1,3} Graham: {testCase.Item2,3} Chocolate: {testCase.Item3,3} Marshmellow: {testCase.Item4,3}\nOutput:\n{f( testCase.Item1, testCase.Item2, testCase.Item3, testCase.Item4 )}\n" );
         }

         Console.ReadLine();
      }
   }
}

Prasowe

  • v1.0 - 204 bytes- Wstępne rozwiązanie.

Notatki

auhmaan
źródło
Doceniany! : D
auhmaan
7

05AB1E , 17 16 bajtów

Zapisano 1 bajt dzięki carusocomputing .

"GCMG"S×vy²Nè.D»

Wypróbuj online!

Kolejność wprowadzania to W, [G,C,M]

Wyjaśnienie

10, [3,2,1] użyty jako przykład.

"GCMG"S           # push the list ['G','C','M','G']
       ×          # repeat each W times
                  # STACK: ['GGGGGGGGGG', 'CCCCCCCCCC', 'MMMMMMMMMM', 'GGGGGGGGGG']
        v         # for each [string, index] y,N in the list
          ²Nè     # get the amount of layers at index N from the [G,C,M] list
         y   .D   # duplicate the string y that many times
               »  # join strings by newlines
Emigna
źródło
1
"GCMG"S×vy²Nè.D»cudowne bliźniacze moce, aktywuj! Formularz, kod 05AB1E! Również argumenty zamieniają się, ale wciąż jest 16.
Magic Octopus Urn
@carusocomputing: Ma tę zaletę, że nie pozostawia niezadrukowanych bzdur na stosie, ale wydaje mi się podobnie nieredukowalne.
Emigna
1
To wciąż 1 bajt mniej i pokonasz remis dzięki MATL;).
Magic Octopus Urn
@carusocomputing: Oooh, kiedy to się stało? Byłem pewien, że było 17, kiedy to zobaczyłem. Ładny! ;)
Emigna
Często publikuję głupie rzeczy i edytuję je 1 minutę po tym, jak zdaję sobie sprawę, że jestem idiotą.
Magic Octopus Urn
6

Ruby, 47 bajtów

->w,g,c,m{puts r=[?G*w]*g,[?C*w]*c,[?M*w]*m,r}

dzięki ventero

Rubinowy, 51 bajtów

->w,g,c,m{(?G*g+?C*c+?M*m+?G*g).chars{|i|puts i*w}}

Zadzwoń tak:

f=->w,g,c,m{(?G*g+?C*c+?M*m+?G*g).chars{|i|puts i*w}}

f[10,3,2,1]
Level River St
źródło
->w,g,c,m{puts r=[?G*w]*g,[?C*w]*c,[?M*w]*m,r}jest nieco krótszy
Ventero
5

PowerShell , 49 bajtów

$a,$b=$args;0..2+0|%{,("$('GCM'[$_])"*$a)*$b[$_]}

Wypróbuj online!

Pobiera dane wejściowe jako cztery argumenty wiersza polecenia, width graham chocolate marshmallowzapisuje pierwszy $ai resztę w $b(domyślnie jako tablicę). Pętle z ponad zakresu 0,1,2,0. Każda pętla indeksujemy do łańcucha GCM, ponownie rzutujemy go charjako łańcuch i mnożymy przez $a(szerokość), a następnie za pomocą operatora przecinkowego ,zamienia to w tablicę, mnożąc odpowiedni indeks $b(tj. Ile warstwy). Wszystkie wynikowe tablice łańcuchowe są pozostawione w potoku, a dane wyjściowe są niejawne, z nową linią między elementami.

AdmBorkBork
źródło
5

C, 108 105 bajtów

Dzięki @Quentin za uratowanie 3 bajtów!

#define F(i,c)for(;i--;puts(""))for(j=w;j--;)putchar(c);
i,j;f(w,g,c,m){i=g;F(i,71)F(c,67)F(m,77)F(g,71)}

Wypróbuj online!

Steadybox
źródło
1
#define F(i,c)for(;i--;puts(""))for(j=w;j--;)putchar(c);oszczędza trzy bajty :)
Quentin
@Quentin Thanks! Zastanawiam się, dlaczego przede wszystkim mi tego brakowało :)
Steadybox
4

Partia, 146 bajtów

@set s=
@for /l %%i in (1,1,%1)do @call set s=G%%s%%
@for %%w in (%2.%s% %3.%s:G=C% %4.%s:G=M% %2.%s%)do @for /l %%i in (1,1,%%~nw)do @echo%%~xw

Opiera się na niejasnym zachowaniu polegającym echona tym, że często może ignorować symbol pomiędzy echoi tekst, który należy echo, aby zwinąć cztery pętle w zagnieżdżoną pętlę.

Neil
źródło
4

V , 22 bajtów

éGÄÀäjMoC
MÀÄkÀÄHdêÀP

Wypróbuj online!

Hexdump:

00000000: e947 c4c0 e46a 4d6f 430a 4d1b c0c4 6bc0  .G...jMoC.M...k.
00000010: c448 64ea c050                           .Hd..P

Kolejność wprowadzania to

Graham, Marshmallow, Chocolate, Width

Wyjaśnienie:

éG                  " Insert 'G'
  Ä                 " Duplicate this line
   Àäj              " *arg1* times, duplicate this line and the line below it
      M             " Move to the middle line
       o            " Open up a newline, and enter insert mode
        C<cr>M<esc> " Insert 'C\nM'
ÀÄ                  " Make *arg2* copies of this line (Marshmallow)
  k                 " Move up one line
   ÀÄ               " Make *arg3* copies of this line (Chocolate)
     H              " Move to the first line
      dê            " Delete this column
        ÀP          " And paste it horizontally *arg4* times
DJMcMayhem
źródło
Czy możesz dodać wyjaśnienie?
programator5000
@ programmer5000 Pewnie! Zobacz moją edycję
DJMcMayhem
4

Excel, 104 bajty

O chłopie! Formuła wymagająca podziału linii.

=REPT(REPT("G",A1)&"
",A2)&REPT(REPT("C",A1)&"
",A3)&REPT(REPT("M",A1)&"
",A4)&REPT(REPT("G",A1)&"
",A2)

A1ma szerokość
A2ma Graham
A3ma czekolada
A4ma ślaz


Jeśli dozwolone jest wstępne formatowanie, możesz sformatować komórkę dla tekstu pionowego i skrócić formułę do 65 bajtów:

=REPT(REPT("G",A2)&REPT("C",A3)&REPT("M",A4)&REPT("G",A2)&"
",A1)
Inżynier Toast
źródło
4

Galaretka , 13 bajtów

“GCM”ẋ"ṁ4Fẋ€Y

Program dyadyczny. Dane wejściowe to: [Graham's, Chocolates, Marshmallows], Width.

Wypróbuj online!

W jaki sposób?

“GCM”ẋ"ṁ4Fẋ€Y - Main link: [g,c,m], w    e.g. [1,2,1], 2
“GCM”         - literal ['G', 'C', 'M']
      "       - zip that and [g,c,m] with the dyadic operation:
     ẋ        -     repeat list               [['G'],['C','C'],['M']]
       ṁ4     - mould like [1,2,3,4]          [['G'],['C','C'],['M'],['G']]
         F    - flatten                       ['G','C','C','M','G']
          ẋ€  - repeat €ach w times           [['G','G'],['C','C'],['C','C'],['M','M'],['G','G']]
            Y - join with line feeds          ['G','G','\n','C','C','\n','C','C','\n','M','M','\n','G','G']
              - implicit print                GG
                                              CC
                                              CC
                                              MM
                                              GG
Jonathan Allan
źródło
3

PHP, 85 bajtów

for($m=$argv;$i++<4;)for($c=$m[_2342[$i]]*$m[1];$c;)echo$c--%$m[1]?"":"\n",_GCMG[$i];

lub

for($m=$argv;$i++<4;)for($c=$m[_2342[$i]];$c--;)echo"\n".str_pad("",$m[1],_GCMG[$i]);

Wersje online

PHP, 96 bajtów

<?[$n,$w,$G,$C,$M]=$argv;for(;$i<4;$i++)for($t=${"$n[$i]"};$t--;)echo"\n".str_pad("",$w,$n[$i]);

Wersja online

Rozszerzony

[$n,$w,$G,$C,$M]=$argv; # $argv[0] must contain a file beginning with "GCMG"
for(;$i<4;$i++) # Take the first 4 values of the filename
for($t=${"$n[$i]"};$t--;) # How many rows should be printed
echo"\n".str_pad("",$w,$n[$i]); # print $w times the actual letter
Jörg Hülsermann
źródło
3

05AB1E , 14 bajtów

Kod:

…GCM‚øü׬)˜S×»

Wykorzystuje kodowanie CP-1252 . Wypróbuj online!

Wyjaśnienie:

…GCM              # Push the string "GCM"
    ‚             # Wrap with the input
     ø            # Transpose the array
      ü×          # Compute the string product of each element (['A', 3] --> 'AAA')
        ¬)˜       # Get the last element and append to the list
           S      # Split the list
            ×     # Vectorized string multiplication with the second input
             »    # Join by newlines and implicitly print
Adnan
źródło
3

Python 2 ,6757 bajtów

(Edycja: teraz, gdy macierze są dozwolone, nie trzeba dołączać nowego wiersza).

def s(w,g,c,m):g=['G'*w]*g;print g+['C'*w]*c+['M'*w]*m+g
rassar
źródło
3

C # (150 bajtów)

void S(int w,int g,int c,int m){P(w,g,'G');P(w,c,'C');P(w,m,'M');P(w,g,'G');}void P(int w,int i,char c){while(i-->0)Console.Write("\n".PadLeft(w,c));}

Nie golfowany:

void SMores(int w, int g, int c, int m)
{
    Print(w,g,'G');
    Print(w,c,'C');
    Print(w,m,'M');
    Print(w,g,'G');
}
void Print(int w, int i, char c)
{
    while(i-->0)
        Console.Write("\n".PadLeft(w,c));
}
Rik
źródło
3

Java, 138 bajtów

String s(int w,int g,int c,int m){String b="";int i=-g-c,j;for(;i++<g+m;){for(j=0;j++<w;)b+=i<=-c|i>m?'G':i<=0?'C':'M';b+="\n";}return b;}

Wypróbuj online!

Wyjaśnienie:

String s(int w, int g, int c, int m) {
    String b = "";
    int i = -g - c, j;              // i is the layer
    for (; i++ < g + m;) {          // Repeat (G+C+M+G) times, starting from -g-c to m+g 
                                    //Layer 0 is the last chocolate layer

        for (j = 0; j++ < w;) {     // Repeat W times
            b += 
                i <= -c | i > m ? 'G': //If before the chocolate or after the marshmellow, output a G
                i <= 0 ? 'C' :      // Else if equal or before last chocolate layer output C
                'M';                //Otherwise output an M
        }
        b += "\n";
    }
    return b;
}
Brenton P.
źródło
3

Szybki, 138 137 134 130 bajtów

Zaoszczędź 7 bajtów dzięki @Kevin

let f=String.init(repeating:count:)
let r={w,g,c,m in f(f("G",w)+"\n",g)+f(f("C",w)+"\n",c)+f(f("M",w)+"\n",m)+f(f("G",w)+"\n",g)}

Dwie funkcje, które zwracają oczekiwaną wartość: fjest funkcją pomocniczą i rjest faktyczną funkcją podobną do lamdba, która generuje dane wyjściowe. Stosowanie: print(r(10,3,2,1))

Sprawdź to!

Pan Xcoder
źródło
Możesz zapisać kilka znaków, odwołując się bezpośrednio do inicjatora ciągu ( var f=String.init(repeating:count:);). I nie oszczędza ci żadnych postaci, ale nie kosztuje, więc obie powinny być let.
Kevin
I jeszcze 3, porzucając jawne argumenty w r( let r={f(f("G",$0)+"\n",$1)+f(f("C",$0)+"\n",$2)+f(f("M",$0)+"\n",$3)+f(f("G",$0)+"\n",$1)})
Kevin,
@Kevin Dzięki, nie miałem pojęcia, że ​​możesz zainicjować wartość czegoś takiego: f=String.init(repeating:count:)...
Pan Xcoder,
@Kevin, jeśli chodzi o twoją drugą sugestię, wydaje się, że przekracza liczbę bajtów w UTF-8, sprawdził liczbę bajtów na TIO, nie wiem dlaczego
Pan Xcoder
2

JavaScript (ES6), 91 bajtów

Obejmuje końcowy znak nowej linii.

f=

(w,g,c,m)=>(b=(`G`[r=`repeat`](w)+`
`)[r](g))+(`C`[r](w)+`
`)[r](c)+(`M`[r](w)+`
`)[r](m)+b

console.log(f(10,3,2,1))

Kudłaty
źródło
2

JS (ES6), 87 bajtów

x=(w,g,c,m)=>(f=>f`Gg`+f`Cc`+f`Mm`+f`Gg`)(([[x,y]])=>(x.repeat(w)+`
`).repeat(eval(y)))

xdziała jako samodzielna funkcja lambda. Wynik ma końcowy znak nowej linii.

Wypróbuj we fragmencie:

Florrie
źródło
2

C, 90 bajtów (na podstawie odpowiedzi Steadyboksa )

Zmieniłem nazwy zmiennych i wykorzystałem operatora preprocesora strunizacji, aby obniżyć parametry makr. Mam nadzieję, że opublikowanie tego pomysłu jako własnej odpowiedzi jest w porządku :)

#define F(x)for(i=x;i--;puts(""))for(j=w;j--;)printf(#x);
i,j;f(w,G,C,M){F(G)F(C)F(M)F(G)}

Łącze TIO

Quentin
źródło
Głosowałby, ale trafił w limit głosów :(
programmer5000
2

F # ( 148 99 bajtów)

let s w q="GCMG"|>Seq.iteri(fun i c->for j in 1..(q|>Seq.item(i%3))do printf"%A"("".PadLeft(w,c)))

Stosowanie:

s 10 [2;3;4]

Nie golfowany:

let smores width quantities =
    "GCMG"
    |>Seq.iteri(fun i char ->
        for j in 1..(quantities|>Seq.nth(i%3))
            do printf "%A" ("".PadLeft(width,char))) 

Nadal jestem nowy na F #, więc jeśli zrobiłem coś dziwnego lub głupiego, daj mi znać.

Rik
źródło
Link do F # byłby miły.
programista
2

JavaScript ES6, 69 68 66 bajtów

Dzięki @Arnauld za grę w golfa o jeden bajt

a=>b=>"GCMG".replace(/./g,(c,i)=>`${c.repeat(a)}
`.repeat(b[i%3]))

Wypróbuj online!

Wyjaśnienie

Odbiera dane wejściowe w formacie curry (Width)([Graham,Chocolate,Marshmallow])

Użycie .replace(/./g,...)zastępuje każdy znak w ciągu GCMGzwracaną wartością z funkcji(c,i)=>`${c.repeat(a)} `.repeat(b[i%3])

`${c.repeat(a)} `tworzy każdą linię crackera grahama z dołączoną nową linią .repeat(b[i%3])powtarza tę linię wymaganą liczbę razy

Fəˈnɛtɪk
źródło
Użycie replace()zapisałoby bajt:a=>"GCMG".replace(/./g,(c,i)=>`${c.repeat(a[0])}\n`.repeat(a[1+i%3]))
Arnauld
1

JS (ES6), 111 bajtów

n=`
`,G="G",C="C",M="M",r=(s,t)=>s.repeat(t),(w,g,c,m)=>r(r(G,w)+n,g)+r(r(C,w)+n,c)+r(r(M,w)+n,m)+r(r(G,w)+n,g)
programmer5000
źródło
1

Mathematica 102 bajtów (100 znaków)

Słyszałem, że wbudowane s'mores nie wychodzi do V12.

s=StringRepeat;StringReplace[s@@@({Characters@"GCMG",#/.#[[4]]->#[[1]]})<>"",x_:>x~s~#[[4]]<>"\n"]&

Całkiem prosto, korzystając z pomysłu zbudowania kolumny jako pierwszej. Długie nazwy funkcji marnują 35 bajtów. Jeden symbol przypominający pudełko jest w rzeczywistości transponowaną postacią i dobrze wklei się do Mathematiki.

Zastosowanie: %@{Graham, Chocolate, Marshmallows, Width} np %@{3, 2, 1, 11}

Kelly Lowder
źródło
1

Java 7, 226 bajtów

String c(int w,int g,int c,int m){return x(w,'G',g)+x(w,'C',c)+x(w,'M',m)+x(w,'G',g);}String x(int w,char c,int x){String r="";for(;x-->0;r+=x(w,c));return r;}String x(int w,char c){String r="";for(;w-->0;r+=c);return r+"\n";}

LUB (także 226 bajtów ):

String c(int w,int g,int c,int m){return x(w,71,g)+x(w,67,c)+x(w,77,m)+x(w,71,g);}String x(int...a){String r="";for(;a[2]-->0;r+=x(a[0],(char)a[1]));return r;}String x(int w,char c){String r="";for(;w-->0;r+=c);return r+"\n";}

Wyjaśnienie:

String c(int w,int g,int c,int m){  // Main method with four integer parameters and String return-type
  return x(w,'G',g)                 //  Return all Graham-rows
        +x(w,'C',c)                 //   plus all Chocolate-rows
        +x(w,'M',m)                 //   Plus all Marshmallon-rows
        +x(w,'G',g);                //   Plus all Graham-rows again
}                                   // End of main method

String x(int w,char c,int x){       // Separate method (1) with two integers & character parameters and String return-type
  String r="";                      //  Result-String
  for(;x-->0;                       //  For the given amount of rows of a certain type
             r+=x(w,c)              //   Append the result-String with a row of the given character
  );                                //  End of for-loop (implicit / no body)
  return r;                         //  Return the result-String
}                                   // End of separate method (1)

String x(int w,char c){             // Separate method (2) with integer and character parameters and String return-type
  String r="";                      //  Result-String
  for(;w-->0;                       //  For the amount given as width
             r+=c                   //   Append the character to the row
  );                                //  End of for-loop (implicit / no body)
  return r+"\n";                    //  Return the result-String including a new-line
}                                   // End of separate method (2)

Kod testowy:

Wypróbuj tutaj.

class M{
  String c(int w,int g,int c,int m){return x(w,'G',g)+x(w,'C',c)+x(w,'M',m)+x(w,'G',g);}String x(int w,char c,int x){String r="";for(;x-->0;r+=x(w,c));return r;}String x(int w,char c){String r="";for(;w-->0;r+=c);return r+"\n";}

  public static void main(String[] a){
    System.out.print(new M().c(10,3,2,1));
  }
}

Wynik:

GGGGGGGGGG
GGGGGGGGGG
GGGGGGGGGG
CCCCCCCCCC
CCCCCCCCCC
MMMMMMMMMM
GGGGGGGGGG
GGGGGGGGGG
GGGGGGGGGG
Kevin Cruijssen
źródło
1
Nieźle ... dla java!
programator5000
1
@ programmer5000 Hehe, dzięki! Lubię grać w golfa w Javie 7 (a czasem 8), chociaż nie sądzę, że kiedykolwiek będzie konkurować z innymi odpowiedziami. Jedynym czasem, kiedy „rywalizowałem” z odpowiedzią Java, była odpowiedź 8 bajtów i odpowiedź 19 bajtów , właściwie po raz pierwszy obezwładnia Pythona. ; p Chociaż te języki gry w golfa z przesłaniem 1 lub 2 bajtów nadal pozostawiają Javę w pyle.
Kevin Cruijssen
1

Haskell , 91 bajtów

import Data.List
(#)=replicate
f w g c m=intercalate"\n"$map(w#)$g#'G'++c#'C'++m#'M'++g#'G'

Powinno to być dość oczywiste. Ponieważ w komentarzu zauważono, że matryce znaków są dozwolone, oto wersja 58-bajtowa, która zwraca listę ciągów znaków (po jednej dla każdej warstwy):

(#)=replicate
f w g c m=map(w#)$g#'G'++c#'C'++m#'M'++g#'G'
Julian Wolf
źródło