Negacja schematu piramidy

13

W moim języku Schemat piramidy jest nieco zabawny: pusty trójkąt:

^
-

Gdy nie podano argumentów, zwraca 0. Aby wygenerować 1za pomocą tego konstruktu, możemy użyć tego:

   ^
  /!\
 ^---
 -

To po prostu przechodzi 0do funkcji negacji. Możemy nadal negować ten wynik:

 ^
/!\
---^
  /!\
 ^---
 -

Aby uzyskać 0. Jeszcze jedna negacja daje:

   ^
  /!\
 ^---
/!\
---^
  /!\
 ^---
 -

Wyzwanie

Biorąc pod uwagę liczbę całkowitą n ≥ 1, wyjmij pustą piramidę negowaną n razy w opisany sposób.

Przypadki testowe

input
output

1
   ^
  /!\
 ^---
 -

2
 ^
/!\
---^
  /!\
 ^---
 -

3
   ^
  /!\
 ^---
/!\
---^
  /!\
 ^---
 -

6
 ^
/!\
---^
  /!\
 ^---
/!\
---^
  /!\
 ^---
/!\
---^
  /!\
 ^---
 -
Conor O'Brien
źródło
Tutaj przez negację mam na myśli bitowe uzupełnienie ( ~)?
user202729,
@ user202729 Nie, mam na myśli regularną negację.
Conor O'Brien
To jest C / C ++ !( not).
user202729,
@ user202729 Tak. Chociaż to, co oznacza, jest styczne do problemu
Conor O'Brien
1
/!\ Ostrzeżenie! /! \ Wszędzie widzę ostrzegawcze trójkąty!
RedClover,

Odpowiedzi:

7

Węgiel drzewny , 17 bajtów

FN«↙^→/!\¶³‖T»↓^-

Wypróbuj online! Link jest do pełnej wersji kodu. Wyjaśnienie:

FN«

Pętla dla odpowiedniej liczby negacji.

↙^→/!\¶³

Wydrukuj funkcję negacji. ( ³Rozwija się do ---.)

‖T

Odbij płótno.

»↓^-

Na końcu pętli wydrukuj pusty trójkąt.

Neil
źródło
Po prostu, pusty trójkąt używa -zamiast_
Conor O'Brien
@ ConorO'Brien Dzięki za zwrócenie na to uwagi! Myślałem, że to nie wygląda dobrze, ale nie mogłem położyć na nim palca ...
Neil,
4

Python 2 , 94 bajty

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

Wypróbuj online!

Próbowanie gry w golfa ... 3 printstwierdzenia wydają się strasznie zbędne.

Pan Xcoder
źródło
2

JavaScript (ES6), 77 74 bajtów

n=>(s=`^
  /!\\
 ^---`,n%2?`   `+s:` ^`)+`
/!\\
---${s}`.repeat(n/2)+`
 -`

Spróbuj:

darrylyeo
źródło
1

Funky , 95 bajtów

n=>{print((n%2)?" ^":"   ^")fori=n i>0i--print({"  /!\\\n ^---","/!\\\n---^"}[i%2])print"   -"}

Wypróbuj online!

ATaco
źródło
1

Proton , 101 bajtów

a=>{k=" ^---"for i:0..a print(["   ^",k,"---^"][i?~i%2+1:i]+"\n"+" "*(~i%2)*2+"/!\\")print(k+"\n -")}

Wypróbuj online!

również za długi lol

HyperNeutrino
źródło
1

Java 8, 104 bajty

n->{String r=n%2>0?"   ^\n":" ^\n";for(;n-->0;r+=n%2<1?"  /!\\\n ^---\n":"/!\\\n---^\n");return r+" -";}

Wyjaśnienie:

Wypróbuj tutaj.

n->{                       // Method with integer parameter and String return-type
  String r=                //  Result-String, starting at:
           n%2>0?          //  If the input is odd:
            "   ^\n"       //   Start the result at "   ^" + new-line
           :               //  Else (the input is even):
            " ^\n";        //   Start the result at " ^" + new-line
  for(;n-->0;              //  Loop the input amount of times
    r+=n%2<1?              //   If the current row is even:
        "  /!\\\n ^---\n"  //    Append the result-String with "  /!\" + new-line
                           //                                  " ^---" + new-line
       :                   //   Else (the current row is odd):
        "/!\\\n---^\n"     //    Append the result-String with "/!\" + new-line
                           //                                  "---^" + new-line
  );                       //  End of loop
  return r                 //  Return the result-String
          +" -";           //   + " -"
}                          // End of method
Kevin Cruijssen
źródło
1

Python 2 , 82 bajty

def f(n):x=n%2;print' '*x*2,'^'+(-~n/2*"\n/!\\\n---^\n  /!\\\n ^---")[x*9:]+'\n -'

Wypróbuj online!

TFeld
źródło
1

Perl 5, 77 + 1 (-p) bajtów

$\=' ^
 _';map$_%2?$\=~s,\^,  ^
  /!\\
 ^---,:$\=~s,  \^,^
/!\\
---^,,1..$_}{

spróbuj online

Nahuel Fouilleul
źródło
0

Python 2 , 100 bajtów

lambda n:n%2*'  '+' ^\n'+'\n'.join(['/!\\\n---^','  /!\\\n ^---'][i%2]for i in range(n,0,-1))+'\n -'

Wypróbuj online!

całkowicie ludzki
źródło
0

C (gcc) , 87 bajtów

f(n){for(puts(n%2?"   ^":" ^");n;)puts(n--%2?"  /!\\\n ^---":"/!\\\n---^");puts(" -");}

Wypróbuj online!

cleblanc
źródło
0

Python 3 , 167 bajtów

def f(n):
	g=[[" "]*5for _ in'  '*-~n];a=["^","/!\\","---"]
	for i in range(n):
		for r,R in zip(a,g[i*2:]):R[(i-n)%2*2+(r>"]"):]=r
	g[-2][1]="^";g[-1][1]="-";return g

Wypróbuj online!

-4 bajty dzięki Mr. Xcoder
-1 bajt dzięki Jonathan Frech

HyperNeutrino
źródło
' '*2*nmoże być ' '*n(dwie spacje tam, ale eugh ... SE Przecena), a następnie ' '*n+' 'mogą być zastąpione przez ' '*-~ndo 168 bajtów .
Pan Xcoder,
@ Mr.Xcoder Och, dziękuję!
HyperNeutrino
Myślę, że r=="^"może być r>"]".
Jonathan Frech,
@JathanathanFrech Wygląda na to, dzięki!
HyperNeutrino,