Haftungsausschluss
Obwohl ich weiß, dass es sich um eine bestimmte verwandte Frage handelt , verwendet meine Frage zwei Garagentore, eine zufällige Komponente, und ich stütze mich dabei auch auf reale Ereignisse, als mein Sohn versehentlich eines dieser Garagentore heruntergelassen hat, als ich aus dem ging Garage letzte Woche ... Nichts wie ein Schlag auf den Kopf, um die kreativen Säfte zum Fließen zu bringen! ;)
Der Hintergrund
Lucas (mein 15 Monate alter Sohn) spielt gern mit der Garagenfernbedienung. Auf dieser Fernbedienung befinden sich zwei Tasten, eine für das linke Garagentor und eine für das rechte Garagentor. Beide Tasten funktionieren auf die gleiche Weise. Einmal drücken, um die Tür zu öffnen, erneut drücken, um anzuhalten, erneut drücken, um zu schließen, erneut drücken, um anzuhalten, und so weiter.
Lucas liebt diese Fernbedienung, er drückt zufällig einen oder beide Knöpfe oder gar keinen. Wenn beide gedrückt werden, wird kein Signal gesendet, aber durch Drücken einer Taste wird ein Signal gesendet.
Die Code-Golf-Herausforderung besteht also aus zwei Teilen:
Teil eins
Generieren Sie eine 60 Zeichen lange Zeichenfolge, die zufällige Lucas-Tastendrücke über eine Minute darstellt. "Zufällig" bedeutet in diesem Fall "mit gleicher Wahrscheinlichkeit für jede Eingabe bei jedem Tick". Die Zeichen sind wie folgt:
- 0: Lucas hat entweder keine Taste gedrückt oder beide Tasten gedrückt. In beiden Fällen wurde kein Signal gesendet.
- 1: Der Knopf für das linke Garagentor wurde von Lucas gedrückt
- 2: Der Knopf für das rechte Garagentor wurde von Lucas gedrückt
Zweiter Teil
Simulieren Sie anhand der in Teil 1 generierten Zeichenfolge das Öffnen und Schließen der Garage für zwei Autos. Verwenden Sie dabei die Zahlen als Auslöser für das Öffnen, Stoppen und Schließen dieser Türen.
Meine Garagentore sind ziemlich schnell (siehe oben, warum). Sobald Sie die Taste gedrückt haben, dauert es vier Sekunden, bis sie vollständig geöffnet oder geschlossen ist.
Also, wenn geschlossen:
- 0 Sek .: 0% offen (geschlossen); Wenn die Taste gedrückt wird, öffnet sich die Tür
- 1 Sek .: 25% geöffnet
- 2 Sek .: 50% offen
- 3 Sek .: 75% offen
- 4 Sek .: 100% geöffnet, Tür bleibt stehen
Und deshalb, wenn offen:
- 0 Sek .: 100% offen; Wenn die Taste gedrückt wird, beginnt sich die Tür zu schließen
- 1 Sek .: 75% offen
- 2 Sek .: 50% offen
- 3 Sek .: 25% offen
- 4 Sek .: 0% offen (geschlossen), Tür bleibt stehen
Wenn eine bestimmte Tür in Bewegung ist, wird sie durch ein Signal an dieselbe Tür gestoppt. Das nächste Signal, das danach an dieselbe Tür gesendet wird, bewegt sich in die entgegengesetzte Richtung. Wird eine Tür angehalten, wenn sie zuvor in Bewegung war und ist jetzt vollständig geöffnet oder vollständig geschlossen, wenn das "Stopp" -Signal empfangen wird, wird die Tür als "angehalten" im vollständig geöffneten oder vollständig geschlossenen Zustand registriert, bereit zu Bewegen Sie sich in die entgegengesetzte Richtung, wenn ein neues Signal eingeht.
Bei dieser Simulation befinden sich beide Garagentore zunächst in der geschlossenen Position. Schauen wir uns also eine 10-Sekunden-Liste mit Befehlen an und sehen, was passiert, wenn Lucas sie auf der Fernbedienung ausführt:
2120221120
2: (L:0% stopped, R:0% opening)
1: (L:0% opening, R:25% opening)
2: (L:25% opening, R:50% stopped)
0: (L:50% opening, R:50% stopped)
2: (L:75% opening, R:50% closing)
2: (L:100% stopped, R:25% stopped)
1: (L:100% closing, R:25% stopped)
1: (L:75% stopped, R:25% stopped)
2: (L:75% stopped, R:25% opening)
0: (L:75% stopped, R:50% opening)
Ausgabe
Der erste Teil der Ausgabe erfordert die Anzeige der 60 Zeichen langen Folge von zufälligen "0" -, "1" - und "2" -Zeichen, die aus Teil 1 generiert wurden. z.B.
212022112021202211202120221120212022112021202211202120221120
Unterhalb dieser Zeichenfolge befindet sich die Verarbeitung dieser "Signale" gemäß den oben genannten Regeln für das Verhalten der Garagentore mit den jeweiligen Zeichen (sekundenweise). Sie sollten am Ende 60 Zeilen unterhalb der anfänglichen Anzeigezeichenfolge haben.
Jede dieser verarbeiteten Zeilen hat folgende Form
N: (L:X% XXXXXXX, R:Y% YYYYYYY)
:
- N ist das n-te Zeichen aus der jeweiligen Zufallszeichenfolge, die die Form einer 0, 1 oder 2 hat.
- X% ist der Prozentsatz der Offenheit der linken Tür (es gibt keine Nullpolsterung)
- XXXXXXX ist der Status der linken Tür. Wenn die Tür nicht in Bewegung ist (dh nicht öffnet oder schließt), wird der Status "gestoppt" erzwungen. Dies bedeutet, dass sie in Bewegung gestoppt wurde (nur bei 25%, 50% oder 75% möglich) oder angehalten wurde, wenn sie vollständig geöffnet ist (100%). ) oder vollständig geschlossen (0%). Andernfalls wird die Tür entweder "geöffnet" oder "geschlossen".
- Y% ist der Prozentsatz der Offenheit der rechten Tür (es gibt keine Nullpolsterung)
- JJJJJJ ist der Status der rechten Tür. Wenn die Tür nicht in Bewegung ist (dh nicht öffnet oder schließt), wird der Status "gestoppt" erzwungen. Dies bedeutet, dass sie in Bewegung gestoppt wurde (nur bei 25%, 50% oder 75% möglich) oder angehalten wurde, wenn sie vollständig geöffnet ist (100%). ) oder vollständig geschlossen (0%). Andernfalls wird die Tür entweder "geöffnet" oder "geschlossen".
Das unten gezeigte Beispiel verwendet 10 "Signale" und 10 verarbeitete Leitungen
2120221120
2: (L:0% stopped, R:0% opening)
1: (L:0% opening, R:25% opening)
2: (L:25% opening, R:50% stopped)
0: (L:50% opening, R:50% stopped)
2: (L:75% opening, R:50% closing)
2: (L:100% stopped, R:25% stopped)
1: (L:100% closing, R:25% stopped)
1: (L:75% stopped, R:25% stopped)
2: (L:75% stopped, R:25% opening)
0: (L:75% stopped, R:50% opening)
Dies ist Code-Golf, so dass der kürzeste Code der klare Gewinner ist. Ich habe das ein wenig vereinfacht, indem ich Sätze wie "Öffnen", "Stoppen" und "Schließen" verwendet habe, die alle aus sieben Buchstaben bestehen. Vielleicht möchten Sie das in Ihre Strategie einarbeiten.
Viel Glück!
1
stoppt der letzte Befehl in Ihrem Beispiel die linke Tür nicht bei 75%?Antworten:
Pyth,
156149145 BytesEine direkte Übersetzung meiner Python-Antwort .
Probieren Sie es online!
Erläuterung:
quelle
Javascript (ES6),
277275263253250247234 BytesUngolfed und kommentiert
Demo
quelle
112200001100122021010101012100000010011200201022122021012211 [ "L:25% stopped", "R:25% stopped" ]
folgt (Zeilenumbrüche nach Komma und Klammern)v^=(c-i-1?0:v&8||24)
, um zwei Bytes zu sparen.Python 2,
377370361357345335326316312306304 BytesDie zweite Einrückungsstufe ist eine rohe Registerkarte (
\t
), die mit Markdown sehr schlecht funktioniert. Sie wurde also durch zwei Leerzeichen ersetzt.Ich bin mir fast sicher, dass dies weiter golfen werden kann.
Ungolfed, mit Kommentaren:
Gespeichert
41415 Bytes dank @TheBikingViking!6 Bytes gespart dank @ValueInk!
quelle
range(60)
zu[0]*60
.'p'[1::3]
anstelle von auch Apostrophe durch Backticks ersetzen''.join(map(str,p))
.(4,0)[q<0]==c[i]and q
->((4,0)[q<0]==c[i])*q
n
um diesen String festzulegen .n
zu extrahieren , ist auf der letzten Zeile verwendetclosing
,stopped
,opening
aus diesem String.Ruby,
263261260254 BytesWie wurde die Antwort von JavaScript so kurz ??? Es hat meins in meiner Abwesenheit überholt und gewinnt derzeit noch ...
quelle
C
420433424374 BytesSät nicht den Zufallsgenerator, sondern verwendet den Zufallsgenerator zur besseren Verteilung. Es muss einen besseren Weg geben, um diese Logik zu spielen ...
Ältere Version 1:
Ältere Version 2:
quelle
PHP,
254247246245235230226 BytesES erneut schlagen!
Golf von diesen 311 (die erste vollständige Version, hatte bereits einige Golf):
Nervenzusammenbruch
quelle
Java 8 Lambda, 500 Zeichen
Ich habe mein Bestes gegeben, hier ist, was mir eingefallen ist:
Ungolfed in eine komplette Klasse:
Ziemlich einfach. Die Variablen stepLeft / stepRight kreisen von 0-3 ab. Mit ein paar einfachen Berechnungen wird changeLeft / changeRight die jeweiligen relativen Änderungen pro Schritt festhalten, die leftDoor / rightDoor hinzugefügt werden. Viele if-Anweisungen, um zu fangen, wann die Tür von selbst anhalten muss.
Fühlen Sie sich frei, mir zu helfen, dies zu verkürzen, ich denke, es gibt viel zu tun.
quelle
Haskell (Lambdabot) - 409 Bytes
quelle
imports
, z. B. fürrandoms
. Wenn es einen Interpreter gibt, der standardmäßig importiert, beziehen Sie sich auf den Namen der Sprache.