Cardinal Code Challenge


24

Aufgabe

Sie sind für die Herstellung eines Kompasses verantwortlich.

Stellen Sie sich Ihren Quellcode als die "Kompassnadel" vor, bei der das Ausführen in verschiedenen Ausrichtungen zu einer unterschiedlichen Ausgabe führt.

Unterstützte Quellcode-Ausrichtungen sind Nord, Ost, Süd und West.

Beispiel

Angenommen, Sie haben Quellcode:

ABCD
 J K
WXYZ

Wir betrachten dies als Nordausrichtung, die uns durch Drehen um 90 Grad im Uhrzeigersinn nach Osten zeigt:

W A
XJB
Y C
ZKD

erneutes Drehen zeigt nach Süden:

ZYXW
K J 
DCBA

und schließlich die letzte Rotation nach Westen:

DKZ
C Y
BJX
A W

Bei der Ausführung sollte jedes der obigen Codebeispiele ein einzelnes druckbares ASCII- Zeichen Ihrer Wahl ausgeben .

Anmerkungen

Ihr Code wird keine Eingabe nehmen.

Leerzeichen oder neue Linien werden beim Drehen nicht ausgeblendet.

Führende / nachfolgende neue Zeilen sind in der Ausgabe in Ordnung.

Antworten können ganze Programme oder Funktionen sein, also an STDOUT ausgegeben werden oder das Funktionsergebnis zurückgeben.

Es gelten die Standardregeln für . kürzeste Antwort in Bytes gewinnt!


Dürfen wir mehr als 1 Zeichen ausgeben?
Mr. Xcoder

1
Müssen wir den Code mit Leerzeichen auffüllen, damit er ein perfektes Rechteck ist (und diese Leerzeichen in unserer Partitur zählen)? Zum Beispiel würde wie förmige Code dies gültig sein, da die ersten die Vorlage ist?
Business Cat

2
Abgesehen von der Ausgabespezifikation denke ich, dass dies ein Duplikat ist
Digital Trauma

1
@BusinessCat Sie müssen Ihren Code nicht auffüllen, um ein Rechteck zu erstellen - das von Ihnen angegebene Beispiel ist gültig.
CzarMatt

4
@ Mr.Xcoder Um, wie könnten 4 identische Programme 4 verschiedene ASCII-Zeichen ausgeben?
ETHproductions

Antworten:


20

Gelee , 2 Bytes

*2

Probieren Sie es online!

Beachten Sie, dass der Haupteintrag für ein Jelly-Programm die letzte Verknüpfung ist, über die ein Zeilenumbruchzeichen Verknüpfungen aufteilt. Keines der zweizeiligen Programme greift tatsächlich auf die oberste Verknüpfung zu.

Die vier vollständigen Programme, die alle implizit das Ergebnis ausgeben, sind:

Norden :

*2   -> (implicit) zero raised to the power of 2 = 0

Osten :

*
2    -> literal 2 = 2

Süden :

2*   -> two raised to the power of (implicit) 2 = 4

Westen :

2
*    -> (implicit) zero raised to the power of (implicit) zero = 1

1
Dies ist die endgültige Antwort. Gut gemacht.
Erik der Outgolfer

19

Japt , 3 2 Bytes

gy

Irgendwie irgendwie , fand ich eine extrem Hacky 2-Byte - Lösung ...


Nord - Ausgänge 0:

gy

Da keine impliziten Eingaben vorhanden sind, ist der Standardwert "" 0. gon a number gibt das Vorzeichen der Zahl unabhängig von ihren Argumenten zurück ( "y"in diesem Fall).


Ost- Ausgänge 2:

g
y

In einem mehrzeiligen Programm setzt die erste Zeile die Eingabe auf das Ergebnis. Dies ist im Grunde ein No-Op, da gauf 0ist 0. Dann ygibt die GCD von 0und ... da es ein Argument fehlt, wird standardmäßig 2(danke, lautet die Standardeinstellung @Oliver !). Dies ergibt 2als Ausgabe.


Süd Ausgänge g:

yg

yist nach wie vor GCD. Da GCD (0, x) ist , x für jeden Wert,y auf0 die Freiheit nimmt nur ihr Argument zurück. In diesem Fall ist das Argument "g", welches das Ergebnis ist.


West Ausgänge1 :

y
g

yon 0 kehrt wie zuvor zurück 2. Dies wird dann an übergeben g, was (wie bereits erläutert) die Vorzeichenfunktion für Zahlen ist. Daher ist das Ergebnis 1.


8

Java (OpenJDK 8) , 7309 4421 855 Bytes

-2888 Bytes dank Leaky Nun
-3566 Bytes dank Wheat Wizard

//i/////////////////////////////////////////////////////////////
//n//////////////////////////////////////////////////////////////////
interface M{static void main(String[]a){System.out.println(0);}}/////
//e//}};)2(nltnirp.tuo.metsyS{)a][gnirtS(niam diov citats{M ecafretni
//r//////////////////////////////////////////////////////////////////
//f}/////////////////////////////////////////////////////////////////
//a}//
//c;//
//e)//
// 3//
//M(//
//{n//
//sl//
//tt//
//an//
//ti//
//ir//
//cp//
// .//
//vt//
//ou//
//io//
//d.//
// m//
//me//
//at//
//is//
//ny//
//(S//
//S{//
//t)//
//ra//
//i]//
//n[//
//gg//
//[n//
//]i//
//ar//
//)t//
//{S//
//S(//
//yn//
//si//
//ta//
//em//
//m //
//.d//
//oi//
//uo//
//tv//
//. //
//pc//
//ri//
//it//
//na//
//tt//
//ls//
//n{//
//(M//
//1 //
//)e//
//;c//
//}a//
//}f//
///r//
///e//
 //t//
 //n//
 //i//

Probieren Sie es online!

Alte Version

Einfacher Ansatz mit Kommentaren, die den Code ^ 2-Quadrat einschließen, dies kann in so ziemlich jeder Sprache erfolgen.
Ein (besser lesbares) Beispiel in Python

##p#####
# r  2 #
print 1#
# n  t #
# t  n #
#4 tnirp
# 3  r #
#####p##

Großartige allgemeine Einschätzung, jetzt muss ich nur noch herausfinden, wie es geht! :)
Fehler

Sie können interface M{static void main(String[]a){System.out.println(0);}}stattdessen verwenden, um einige Bytes zu speichern.
Undichte Nonne


1
@MagicOctopusUrn es wurde nicht von Hand gemacht c;
Rod

1
@MagicOctopusUrn nah, ich habe diese Antwort gemacht, um diesen Algorithmus zu zeigen, die Sprache ist irrelevant: 3
Rod

7

Brain-Flak , 33 Bytes

##)(##))()()  ((
((  ))##    ()##

Probieren Sie es online!

Brain-Flak , 33 Bytes

##)     ## #
(( ))#)())()
  # ( (

Probieren Sie es online!

Brain-Flak , 36 Bytes

#)##     ## #
  (())#)())()
 #   ( (

Probieren Sie es online!

Brain-Flak , 38 Bytes

######  (#
(()()())#))((
       #(  ##

Probieren Sie es online!

Brain-Flak , 41 Bytes

##(#####(#
(()()())#
##))()((
####((#)#)#

Probieren Sie es online!


Heiliger Strohsack! Ich habe an einem gearbeitet, aber ich konnte nicht weiterkommen. Ich dachte, es würde mindestens 30-40 Minuten dauern, um etwas herauszufinden. Das ist großartig!
DJMcMayhem

1
Das ist sehr cool!
CzarMatt

Versuchen Sie Golf zu spielen: P haben 3 von ihnen arbeiten
Christopher


5

Befunge, 17 13 Bytes

Ich dachte, Befunge würde bei einem geometrischen Problem Spaß machen. Es gibt eine einfache 4x4-Lösung, die mit anderen hier vergleichbar ist (ich benötige 3 Befehle), aber ich habe es ein bisschen besser geschafft.

Edit: Newlines vergessen

Edit 2: erkannte, dass ich eine Katze erschaffen konnte

Edit 3: Die Katze ist tot

2v3
@.v
.  
1@.

RIP Kitty: <

1.@ 2
^._.^
3 @.4

5

05AB1E , 5 3 Bytes

Y'X

Norden , Osten , Süden , Westen


Beeindruckend, das ging schnell!
CzarMatt

@MagicOctopusUrn Ich denke das Y'Xwird funktionieren, aber ich muss es trotzdem versuchen.
Riley

@Riley tut es, funktioniert auch vorwärts und rückwärts, Y'Xist auch gültig. Ich suche immer noch nach einem 2-Byte-Wert. Keiner der 'Punktbefehle' funktioniert dafür, daher bezweifle ich, dass er existiert.
Magic Octopus Urn

@MagicOctopusUrn Ich glaube nicht, dass es eine 2-Byte-Lösung gibt, wie Newlines funktionieren. Es wäre jedoch nicht schwer, Force zu brutalisieren.
Riley

10hätte funktioniert, wenn sie mehrere Zeichen für eine Ausgabe zugelassen hätten; P. *
Magic Octopus Urn

4

C (gcc) , 283 279 209 Bytes

/////////)pm//
/////////;ua//
main(){//}ti//
puts("N"//sn//
);}///////((//
//////////")//
///"//////W{//
///E//////"///
//)"//////////
//((///////};)
//ns//"S"(stup
//it}//{)(niam
//au;/////////
//mp)/////////

Probieren Sie es online!

Selber alter Kommentar-Trick hier, aber zumindest in C wird das nicht riesig ;)


Benötigen Sie einen der vier Schrägstriche am rechten Rand direkt über der Lücke?
ETHproductions

Hey ... ähm ... ich denke, eigentlich ... nein. Guter Fang, danke :)
Felix Palmen

Ich denke , dass Sie es zusammen ziemlich viel enger , indem jede Packung können );}auf die Linie unten, wie so (ich habe nicht die Drehungen getestet though)
ETHproductions

Oh, das WProgramm in Ihrem aktuellen Setup schlägt derzeit fehl, da snnach dem eigentlichen Code ein zusätzliches steht . Anscheinend können Sie dies beheben, indem Sie den Schrägstrich direkt vor pmder obersten Zeile in ein Semikolon ändern .
ETHproductions

uhh ... wahrscheinlich ist es an der Zeit, dies zu löschen und von vorne zu beginnen: o (die erste Version bestand aus Schrägstrichen, aber ich dachte, ich würde ein " cleveres " Ding machen, um ein paar Bytes zu sparen ... verdammt)
Felix Palmen

4

Labyrinth , 9 Bytes

!
2@2
 !)

Druckt 0. Probieren Sie es online!

 2)
 @!
!2

Druckt 3. Probieren Sie es online!

)!
2@2
  !

Druckt 1. Probieren Sie es online!

 2!
!@
)2

Druckt 2.Probieren Sie es online!

Erläuterung

Jedes Programm beginnt mit dem ersten Leerzeichen in der Lesereihenfolge (dh entweder dem Zeichen oben links oder oben in der Mitte) und bewegt sich nach Osten. Für das erste Programm:

!   Print an implicit zero.
    The IP can't move east, so it moves south instead.
2   Push a 2.
    The IP can't keep going south, so it turns east instead.
@   Terminate the program.

Für das zweite Programm:

2   Push a 2.
)   Increment it to 3.
    The IP can't keep going east, so it turns south instead.
!   Print the 3.
    The IP can't keep going south, so it turns west instead.
@   Terminate the program.

Für das dritte Programm:

)   Increment an implicit zero to 1.
!   Print the 1.
    The IP can't keep going east, so it turns south instead.
@   Terminate the program.

Für das vierte Programm:

2   Push a 2.
!   Print the 2.
    The IP can't keep going east, so it turns back around to move west.
2   Push another 2.
    The IP can't keep going west, so it turns south instead.
@   Terminate the program.

4

Wumpus , 7 Bytes

O@$
)))

Druckt 0.Probieren Sie es online!

)O
)@
)$

Druckt 1.Probieren Sie es online!

)))
$@O

Druckt 3.Probieren Sie es online!

$)
@)
O)

Druckt 2. Probieren Sie es online!

Erläuterung

Das erste Programm ist einfach genug: O druckt eine implizite Null und@ beendet das Programm.

Ab dem zweiten Programm müssen wir uns das dreieckige Raster ansehen, um den Kontrollfluss zu verstehen:

Bildbeschreibung hier eingeben

)   Increment an implicit zero to 1.
O   Print the 1.
))  Two irrelevant increments.
@   Terminate the program.

Für das dritte Programm:

Bildbeschreibung hier eingeben

))) Increment an implicit zero to 3.
O   Print the 3.
@   Terminate the program.

Das vierte ist, wo es wirklich funky wird. Gestrichelte Linien kennzeichnen Zellen, die nicht ausgeführt werden, weil sie vom folgenden Befehl übersprungen werden $:

Bildbeschreibung hier eingeben

$   Skip the ).
$   Skip the @.
))  Increment an implicit zero to 2.
O   Print the 2.
))  Two irrelevant increments.
@   Terminate the program.

Super cool, tolle Diagramme auch.
CzarMatt

3

PowerShell , 20 11 Bytes

#4#
1#3
#2#

Missbräuche Kommentare ( #) mögen verrückt sein, und die Tatsache, dass eine einzelne Zahl, die in die Pipeline eingefügt wird, unverändert ausgegeben wird. Die oben genannten Drucke 1.Probieren Sie es online!

An dieser Stelle können Sie leicht erkennen, dass jede Drehung nur eine Zahl "links" in den Kommentaren ergibt und somit nur eine Zahl pro Drehung ausgegeben wird.

Dank Wheat Wizard 9 Bytes gespart !


Sie wissen nicht , Powershell, aber würde nicht diese Arbeit?
Weizen-Zauberer

@ WheatWizard Ja, in der Tat. Vielen Dank!
AdmBorkBork

3

Sternenhimmel , 34 Bytes

  zz  
  +   
   .  
    + 
      

Oder mit Leerzeichen, die als Bindestriche angezeigt werden, damit Sie sie sehen können:

--zz--
--+---
---.--
----+-
------

Probieren Sie es online!

Die Befehle in Starry sind +, .und einige andere Dinge, und was sie tun , ist dadurch bestimmt, wie viele Räume gibt , bevor sie sind: eine +mit n Leerzeichen Schübe n -5 auf den Stapel, und. mit einer geraden Anzahl von Räumen druckt. Das zs und die Zeilenumbrüche werden vollständig ignoriert.

Es gibt 6 Leerzeichen vor dem ersten + also drückt es 6−5 = 1 und .druckt es aus.

Und die Drehungen:

-----
-----
---+z
--.-z
-+---
-----

Probieren Sie es online!Dies druckt "8".

------
-+----
--.---
---+--
--zz--

Probieren Sie es online!Dies druckt "2".

-----
---+-
z-.--
z+---
-----
-----

Probieren Sie es online! Und dies druckt "3".


Was für eine nette Sprache. Außerdem habe ich nie gesagt, dass Sie mit Leerzeichen auffüllen müssen, um ein Rechteck zu bilden. Wenn sich Ihre Quelle jedoch auf die Leerzeichen stützt, müssen Sie sie vermutlich zählen.
CzarMatt

@CzarMatt, danke für die Klarstellung! Ich habe den Beitrag aktualisiert.
Kein Baum


2

Batch, 90 Bytes

 :: :::@:
:&s ohce@
:e   : c:
      :h:
:o     o:
:h:
:c :   w:
@echo n&:
:@::: ::

Batch hat eigentlich keinen Kommentarcharakter. Bei ganzzeiligen Kommentaren :funktioniert dies, da es eine Bezeichnung einführt, aber ich benötige immer noch etwas, um den echoBefehl zu beenden, während ich im umgekehrten Fall ein No-Op bin. &:scheint zu funktionieren, was hier alles ist, was ich brauche, aber es verwirrt Batch wirklich, macht einen Fehler, wenn ich in der nächsten Zeile kein :vor das setze @, und vergisst irgendwie, eine neue Zeile zu drucken.


2

MATLAB, 29 17 5 11 Bytes

Nachdem wir erkannt haben, dass die Frage nach einzelnen ASCII-Zeichen und nicht nur nach einer bestimmten Ausgabe lautet, folgt ein MATLAB-Ansatz, der genau dies ermöglicht:

%4%
1%3
%2%

Dies gibt implizit 1, 2, 3 oder 4 aus, abhängig von der Drehung.


Wenn Sie sich das überlegen, würde dies auch in MATL funktionieren. Gleiche Byteanzahl wie meine.
Sanchises



1

JS, 17B

//1//
2///4
//3//

Ausgänge:
Nord: 2,
Ost: 3,
Süd: 4,
West: 0,33333333333….
(wie in: 2, 3/1, 4, 1/3)


Willkommen bei PPCG! Ich glaube nicht, dass dies gültig ist, da in einer Nicht-REPL-Umgebung die Nummer nicht angezeigt wird. (Ich könnte mich da irren)
Zacharý

(
Fügen

1
Die Ausgabe sollte ein einzelnes druckbares ASCII-Zeichen sein. Wie bei meinem MATLAB ist dies ungültig.
Tom Carpenter

1

Entschuldigung, ich meinte:

//0//
////
 1/2
/////
//3//

und 28B. Und Ausgänge als 0,5, 3, 2, 0.


Willkommen bei PPCG! Sie sollten den Namen der Sprache und die Anzahl der Bytes in eine Kopfzeile einfügen. Und dies ist ein Ausschnitt, kein vollständiges Programm oder eine Funktion, die nicht gültig ist. (Ich könnte mich irren)
Zacharý

@ Zacharý Ich denke, codegolf.meta.stackexchange.com/questions/7842/… sagt, dass REPLs erlaubt sind
SuperStormer

In jedem Fall sollten sie angeben, dass es sich um eine JS-REPL handelt.
Zacharý

2
Die Ausgabe sollte ein einzelnes druckbares ASCII-Zeichen sein. Wie bei meinem MATLAB ist dies ungültig.
Tom Carpenter

1

JavaScript (ES6), 86 Byte

Ausgänge 0 für Nord, 1 für Ost, 2 für Süd und 3 für West.

////  _//
////  =//
_=>0//>//
  ////1//
  // //
//3////
//>//2>=_
//=  ////
//_  ////


1

MATL , 11 Bytes

HxI
xFx
TxK

Probieren Sie es online!

Beginnen wir damit in MATL. Die größte Herausforderung besteht darin, dass MATL nur dann fehlschlägt, wenn für eine Funktion eine Eingabe erforderlich ist, wenn der Stapel leer ist. Vielleicht etwas gescheites mit Modifikatoren wieX , Y, Zund &kürzer für etwas machen könnte, aber ich konnte keine passende Kombination finden.

Erläuterung: Alle Zeichen verschieben eine einzelne Ganzzahl auf den Stapel und xentfernen alle Zeichen außer dem letzten.


1

Perl, 49 Bytes

48 Byte Code + 1 für -p.

Nimmt eine leere Eingabe an, die von TIO nicht unterstützt wird. Daher wird an ihrer Stelle eine neue Zeile hinzugefügt und nicht verwendet. Druck N , E , S , W .

# ####
#S= _$
#; W#
 $_=N#
#_ _#
#= $#
#E#
 ## #

Probieren Sie es online!


1

C (gcc) , 120 Bytes

Ich hatte mir mehr Synergie zwischen den Varianten erhofft.

//}=)f8 ///
// c{(7 ///
   ;rr; //}
        ;c=
78; /// r{)
f(r /// r(f
){r /// ;38
=c;
}// ;rr;
/// 9({c //
/// 6f)=}//

Norden

Osten

Süd

Westen

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.