Einige Berggipfel zeichnen


33

Schreiben Sie ein Programm oder eine Funktion, die einen Gebirgszug zeichnet, bei dem jeder nachfolgende größere Berggipfel "hinter" dem vorderen liegt und abwechselnd die sichtbare Seite anzeigt.

Dies ist eine Bergkette von Größe 1

/\

Dies ist eine Bergkette von Größe 2

 /\
/\ \

Dies ist eine Bergkette von Größe 3

  /\
 / /\
/ /\ \

Dies ist eine Bergkette von Größe 4

   /\
  /\ \
 / /\ \
/ /\ \ \

Dies ist eine Bergkette von Größe 5

    /\
   / /\
  / /\ \
 / / /\ \
/ / /\ \ \

Und so weiter.

Eingang

Eine einzelne positive ganze Zahl in jedem geeigneten Format , n > 0.

Ausgabe

Eine ASCII-artige Darstellung des Gebirges nach den oben genannten Regeln. Führende / nachfolgende Zeilenumbrüche oder andere Leerzeichen sind optional, sofern die Spitzen richtig ausgerichtet sind.

Regeln

  • Es ist entweder ein vollständiges Programm oder eine Funktion zulässig. Bei einer Funktion können Sie die Ausgabe zurückgeben, anstatt sie zu drucken.
  • Standardlücken sind verboten.
  • Dies ist daher gelten alle üblichen Golfregeln, und der kürzeste Code (in Byte) gewinnt.

Antworten:


14

Kohle , 16 Bytes

NλFλ«P↘⁻λι←↙¹‖T→

Probieren Sie es online!

Wie?

Nλgibt die Größe des größten Berges ein λ. Fλ«Läuft eine Schleife über Werte von ιvon 0bis λ-1. (Der Abschluss »ist am Ende des Programms impliziert.)

P↘⁻λιBerechnet λ-ιund zeichnet innerhalb der Schleife eine Linie dieser Länge nach Südosten, ohne den Cursor danach zu bewegen. Diese Zeile besteht je nach Richtung aus \Zeichen. bewegt sich einen Schritt nach Westen und ↙¹zeichnet eine Linie der Länge 1 nach Südwesten (aus /). Schließlich ‖T→spiegelt sich horizontal um die Zeichnung, Zeichen gegebenenfalls Umwandlung: \wird /und /wird \.

Durch Hinzufügen der Dump-Anweisung am Anfang der Schleife ( probieren Sie es aus ) können wir den Fortschritt sehen:

    /\
   /  
  /   
 /    
/     
    /\    
   /\ \   
  /    \  
 /      \ 
/        \
    /\    
   / /\   
  / /\ \  
 / /    \ 
/ /      \
    /\    
   /\ \   
  / /\ \  
 / /\ \ \ 
/ /    \ \
    /\    
   / /\   
  / /\ \  
 / / /\ \ 
/ / /\ \ \

2
Ich denke, dies ist die ideale Sprache für die Herausforderung :-)
ETHproductions

@ETHproductions Diese Sprache wurde speziell für ASCII-Grafiken erstellt. Es hat auch eine eigene Codepage.
Erik der Outgolfer

@EriktheGolfer Ich habe meine eigene (nicht implementierte) ASCII-Kunstsprache, Crayon . Die Dokumente sind im Moment irgendwie verloren, weil ich gerade dabei bin, sie zu verschieben, aber Sie können die meisten hier sehen . Ich frage mich, wie kurz ein Crayon-Programm dafür im Vergleich zu Charcoal wäre ...
ETHproductions

@ETHproductions Wann werden Sie es implementieren? Gibt es einen Chatroom dafür oder kann ich einen erstellen ("Crayon Implementation")?
Erik der Outgolfer

@EriktheGolfer Leider weiß ich nicht, wann ich Zeit habe, es umzusetzen. Aber Sie können einen Chatroom erstellen, wenn Sie
möchten ;-)

7

JavaScript (ES6), 75 Byte

for(n=prompt(s="/\\");n--;s=n%2?s+' \\':'/ '+s)console.log(" ".repeat(n)+s)

Das vollständige Programm ist derzeit etwas kürzer als die rekursive Funktion:

f=n=>n?" ".repeat(--n)+`/\\
`+f(n).replace(/\S.+/g,x=>n%2?x+" \\":"/ "+x):""

6

Python 2, 67 Bytes

n=input()
s='/\\'
while n:n-=1;print' '*n+s;s=['/ '+s,s+' \\'][n%2]

Druckt zeilenweise und akkumuliert die Zeichenfolge, sindem abwechselnd ein Schrägstrich nach links oder rechts hinzugefügt wird, basierend auf der aktuellen Parität von n. Präfixe mit nLeerzeichen.

Eine alternative Möglichkeit zum Aktualisieren war die gleiche Länge:

s=n%2*'/ '+s+~n%2*' \\'
s=['/ '+s,s+' \\'][n%2]

Eine rekursive Methode war länger (70 Byte).

f=lambda n,s='/\\':n*'_'and' '*~-n+s+'\n'+f(n-1,[s+' \\','/ '+s][n%2])

6

Haskell, 77 Bytes

0%_=""
n%s=(' '<$[2..n])++s++'\n':(n-1)%(cycle[s++" \\","/ "++s]!!n)
(%"/\\")

Verwendung:

putStrLn $ f 5
    /\
   / /\
  / /\ \
 / / /\ \
/ / /\ \ \

Druckt Zeile für Zeile, wobei die Zeichenfolge s durch abwechselndes Hinzufügen eines Schrägstrichs nach links oder rechts basierend auf der aktuellen Parität von n akkumuliert wird. Präfixe mit n-1 Leerzeichen.


5

Batch, 202 Bytes

@echo off
set/af=%1^&1
set m=/\
set s=
for /l %%i in (2,1,%1)do call set s= %%s%%
for /l %%i in (2,1,%1)do call:l
:l
echo %s%%m%
set s=%s:~1%
set/af^^=1
if %f%==1 (set m=%m% \)else set m=/ %m%

Übernimmt die Eingabe als Befehlszeilenparameter. Fällt durch, um die letzte Schleife auszuführen.


@TimmyD Sorry, ich habe beim Golfen getippt. Jetzt behoben.
Neil


5

Haskell, 117 107 105 97 90 Bytes

b!1=["/\\"]
b!n|m<-(1-b)!(n-1)=map(' ':)m++[[("/ "++),(++" \\")]!!b$last m]
(unlines.(1!))

Probieren Sie es auf Ideone. Bearbeiten: 8 Bytes mit einer Idee von Neil gespeichert.

Ungolfed-Version:

p b 1 = ["/\\"]
p b n = let m = p (1-b) (n-1)
            k = last m
            r = map (' ':) m
        in if b == 1
           then r ++ [k ++ " \\"]
           else r ++ ["/ " ++ k]
f n = unlines(p 1 n)

Rekursiver Ansatz. Die Form für nwird erzeugt, indem vor jeder Zeile der n-1Form ein Leerzeichen eingefügt und die letzte Zeile von n-1und addiert wird, "/ "bevor ob nungerade ist oder " \"nachdem ob gerade nist ... oder so alle rekursiven Schritte, wenn das Finale nungerade ist. Daher wird ein Flag bübergeben, das jeden rekursiven Aufruf abwechselt und bestimmt, ob der nächste Bergabschnitt links oder rechts hinzugefügt wird.


1
Können Sie nicht einfach ein Flag am Anfang übergeben und es bei jedem rekursiven Aufruf umdrehen, anstatt es bmit odd njedem Zeitpunkt zu vergleichen ? Sowas wie f n = unlines(p 0 n)und let m = p (1-b) (n-1).
Neil

Das Umblättern zu -bist ein weiterer Zeichen aus.
Xnor

@xnor Danke für den Hinweis, aber ich fand einen anderen Weg zum Golf es weiter , die benötigt bwerden , um 0oder 1.
Laikoni

2

Java 7.130 Bytes

String f(int n,String s){String l="";for(int i=1;i++<n;l+=" ");return n>1?n%2<1?l+s+"\n"+f(--n,s+" \\"):l+s+"\n"+f(--n,"/ "+s):s;}

Ungolfed

class Mountain {
 public static void main(String[] args) {
    System.out.println(f( 5 , "/\\" ) );
  }
 static String f(int n,String s){
    String l = "";
    for (int i = 1; i++ < n; l += " ") ;
      return n > 1? n % 2 < 1?l + s + "\n" + f(--n , s + " \\")
                           :l + s + "\n" + f(--n , "/ " + s)
                            :s;
    }

}

Gute Antwort, +1. Sie können es durch 2 Bytes aber Golf spielen: n%2zu n--%2und beide --nzu n. EDIT: Und 1 mehr durch Hinzufügen ,x=s+"\n"und Ändern von beiden s+"\n"zu x. (Also insgesamt: String f(int n,String s){String l="",x=s+"\n";for(int i=1;i++<n;l+=" ");return n>1?n--%2<1?l+x+f(n,s+" \\"):l+x+f(n,"/ "+s):s;} 127 Bytes )
Kevin Cruijssen

0

C ++ 138 (Funktion)

Funktion: -

#define c(X) cout<<X;
#define L(X,Y) for(X=0;X<Y;X++)  

void M(int h){int l=1,r=1,j,H=h,i;L(i,h){for(j=H;j>0;j--)c(" ")L(j,l)c(" /")L(j, r)c("\\ ")c("\ n")(h%2)?(i%2)?r++:l++:(i%2)?l++:r++;H--;}  

Volles Programm: -

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

using namespace std;

#define c(X) cout<<X;
#define L(X,Y) for(X=0;X<Y;X++)

void M(int h)
{
    int l=1,r=1,j,H=h,i;

    L(i, h)
    {
        for (j = H;j > 0;j--)
            c(" ")
        L(j, l)
            c(" /")
        L(j, r)
            c("\\ ")
        c("\n")

        (h % 2) ? (i % 2) ? r++ : l++ :(i % 2) ? l++ : r++;
        H--;
    }
}

int main()
{
    int h;
    cin >> h;
    M(h);
    _getch();
    return 0;
}  

HINWEIS: Die Funktion _getch()kann auf verschiedenen Compilern unterschiedliche Prototypnamen haben.

Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.