Montag Minigolf: Eine Reihe von kurzen Code-Golf- Herausforderungen, die (hoffentlich!) Jeden Montag veröffentlicht werden.
Wahre Begebenheit 1 : Neulich spielte ich auf meinem Tablet herum, als ich auf die Idee kam, die Seite zu besuchen, die ich normalerweise auf meinem PC zum Testen von JavaScript verwende. Nachdem die Seite geladen war, habe ich dieses einfache Programm aufgerufen:
alert("Hello!")
Ich drückte dann die Execute-Taste und war überrascht, als mir mitgeteilt wurde, dass der von mir eingegebene Code ungültig war. Ich warf einen zweiten Blick auf das Textfeld und sah Folgendes:
alllelelerlerlertlert("Heeelelellellelloello!")
Was ??? Das habe ich nicht eingegeben! Also, was ist hier passiert? Um das herauszufinden, habe ich zwei einfache Zeilen eingegeben:
abcdefg
0123456
Dies stellte sich heraus als:
abbbcbcbcdbcdbcdebcdebcdefbcdefbcdefgbcdefg
0112123123412345123456
Inzwischen hatte ich noch keine Ahnung, was mit den Buchstaben geschah, aber die Zahlen schienen einfacher zu sein, also schaute ich genauer hin. Wie sich herausstellte, gab die Webseite einfach das erste Zeichen ein und wiederholte den Rest der Zeichenkette jedes Mal, wenn ein neues gedrückt wurde:
0112123123412345123456
0
1
12
123
1234
12345
123456
Aber was ist mit den Buchstabenabschnitten? Nachdem ich eine Minute lang nachgedacht hatte, wurde mir klar, dass es genau dasselbe ist, aber anstatt jeden Unterabschnitt einmal zu wiederholen, wird es zweimal wiederholt :
abbbcbcbcdbcdbcdebcdebcdefbcdefbcdefgbcdefg
a
bb
bcbc
bcdbcd
bcdebcde
bcdefbcdef
bcdefgbcdefg
Eine Kombination der beiden funktioniert mit einer Kombination dieser Techniken:
abc123z
abbbcbcbc1bc12bc123bc123zbc123z
a
bb
bcbc
bc1
bc12
bc123
bc123zbc123z
Was auch immer Störimpulse verursachen mag, diese scheinen sich bei Interpunktion und Leerzeichen zurückzusetzen, so abc def
wird es abbbcbc deeefef
.
Zu diesem Zeitpunkt war ich so fasziniert, es herauszufinden und es zu einer interessanten Herausforderung zu machen, dass ich vergaß, warum ich überhaupt dort gewesen war. (Ich habe jedoch herausgefunden, wie man normal schreibt: Drücken Sie die Leertaste nach jedem Zeichen. Ziemlich langweilig, aber Sie müssen tun, was Sie tun müssen.)
Herausforderung
Ziel der Herausforderung ist es, ein Programm oder eine Funktion zu schreiben, die den zu verarbeitenden Text aufnimmt, die oben aufgeführten Änderungen vornimmt und das Ergebnis ausgibt / zurückgibt.
Einzelheiten
- Die Eingabe enthält nur druckbares ASCII und keine Tabulatoren oder Zeilenumbrüche.
Testfälle
Eingänge: (einer pro Zeile)
Mess up text
This is some longer text.
CAPS LOCK && "Punc-tua"+'tion'
under_score_style
CaPs wItHIn loWERs
1337 numb3r5
abcdefghij 0123456789
Code-golf is the best!
Ausgänge:
Meeesesessess upp teeexexextext
Thhhihihishis iss sooomomomeome looononongongongeongeongeronger teeexexextext.
CAAAPAPAPSAPS LOOOCOCOCKOCK && "Puuunununcunc-tuuuaua"+'tiiioioionion'
unnndndndendendernder_scccococorcorcorecore_stttytytyltyltyletyle
CaaaPaPaPsaPs wIIItItItHItHItHIItHIItHInItHIn loooWoWoWEoWEoWERoWERoWERsoWERs
1333337 nuuumumumbumbumb3umb3rumb3rumb3r5
abbbcbcbcdbcdbcdebcdebcdefbcdefbcdefgbcdefgbcdefghbcdefghbcdefghibcdefghibcdefghijbcdefghij 0112123123412345123456123456712345678123456789
Cooodododeode-gooolololfolf iss thhhehe beeesesestest!
Wertung
Das ist Code-Golf , also gewinnt der kürzeste gültige Code in Bytes. Tiebreaker geht zur Übermittlung über, die als erste ihre letzte Bytezahl erreicht hat. Der Gewinner wird am kommenden Montag, 2. November, ermittelt. Viel Glück!
Edit: Und der Gewinner ist ... @ MartinBüttner benutzt Retina für eine unglaubliche 43-Byte- Lösung!
1 Ja, diese Geschichte ist völlig richtig, und wenn Sie weitere Erläuterungen benötigen, siehe Fußnote 1.
' '.join(x[0]+''.join(2*x[1:i]for i in range(1,len(x)+1)) for x in raw_input().split())
Antworten:
Retina , 43 Bytes
Führen Sie den Code aus einer einzelnen Datei mit dem
-s
Flag aus. Da es sich nur um eine einzelne Regex-Ersetzung handelt, können Sie diese hier testen (klicken Sie auf die Registerkarte "Kontext", um die Ergebnisse anzuzeigen).Erläuterung
Dies entspricht jeder Ziffer und jedem Buchstaben, die nicht die erste in einem Lauf sind. Während
.
jedes Nicht-Zeilenvorschub-Zeichen passen kann, stellen die Lookbehinds die anderen Bedingungen sicher:Dies entspricht rückwärts von der Position nach dem
.
. Erstens paßt es ein oder mehr alphanumerische Zeichen und erfasst sie in der Gruppe1
mit([^_\W]+)
. Dies stellt sofort sicher, dass das.
einem alphanumerischen Zeichen selbst entspricht. Dann stellt der Zusatz[^_\W]
sicher, dass es im aktuellen Lauf noch ein alphanumerisches Zeichen gibt, das wir nicht mit einbeziehen. Jetzt1
wollen wir die Übereinstimmung durch eine Gruppe ersetzen, wenn es sich um eine Ziffer handelt. Wenn es sich um einen Buchstaben handelt, möchten wir ihn durch die doppelte Zeichenfolge ersetzen. Hier kommt der zweite Lookbehind ins Spiel:Dieser ist optional. Wenn er fehlschlägt, hat dies keinerlei Auswirkungen auf die Übereinstimmung. Es wird zunächst sichergestellt, dass
.
es sich nicht um eine Ziffer handelt.(?<=\D)
Dieser Lookbehind ist also nur relevant, wenn Buchstaben übereinstimmen. In diesem Fall stimmen wir erneut mit der Gruppe überein\1
(dies stimmt immer überein, da wir die Gruppe von derselben Position aus erfasst haben), erfassen sie jedoch in der Gruppe2
.Daher ersetzen wir einfach den regulären Ausdruck durch den Inhalt beider Gruppen (
$1$2
). Wenn die Übereinstimmung eine Ziffer war, ist$2
sie immer noch leer und wir schreiben das Präfix nur einmal zurück. Wenn es ein Brief war,$2
ist derselbe wie$1
und wir schreiben ihn zweimal zurück.quelle
JavaScript (ES6) 82
Verwendung der von Mwr247 vorgeschlagenen Regexp-Optimierung
Testen Sie das folgende Snippet in einem aktuellen Browser
quelle
JavaScript (ES6),
928887Ich habe keine Ahnung, wie ich Golf spielen soll ...
Vielen Dank an Mwir247 für den Golf-Down-Regex und an ETHproductions für den 1-Byte-Golf-Down-Funktion .
quelle
/[^_\W]+/g
(Speichert 3 Zeichen).reduce
Funktion funktionieren:(a,e)=>a+=(y+=e,++e?y:y+y)
(1 Byte kürzer)Haskell,
215200 BytesEs ist ein Chaos.
Viel Spaß beim Lesen all der seltsamen Macken, ich hätte nie gedacht, dass ich so
id
viel verwenden würde.Schade , dass die Sachen , die schon funktioniert die Hälfte der Arbeit hier muss importiert werden (
isDigit
,isAlpha
,inits
).quelle
lang-hs
nichtlang-haskell
. Durch die Angabelang-haskell
wird wahrscheinlich ein Standard-Textmarker verwendet.Gema, 57 Zeichen
Probelauf:
quelle
Haskell,
183181 BytesVerwendungszweck:
Ich weiß nicht, ob es mit der Antwort von Leif Willerts wesentlich anders ist. Aber hier ist der Algorithmus.
Ich halte irgendwie überflüssige Klammern.
quelle
T-SQL, 357 Bytes
Beispiel:
exec x(@s='1337 numb3r5')
kehrt zurück1333337 nuuumumumbumbumb3umb3rumb3rumb3r5
quelle
Python 2, 131 Bytes
Durchläuft Zeichen und speichert / wiederholt sie bei Bedarf.
quelle
Pip, 41 Bytes
Nimmt den Text als Befehlszeilenargument. Wir verwenden eine Regex-Ersetzung, um alle alphanumerischen Ausführungen (
[^_\W]+
) durch eine Rückruffunktion zu ersetzen . Diese Funktion ordnet jedem Zeichen des Wortes eine weitere Funktion zu, wobei immer größere Zeichenfolgen generiert werden (wobei die globale Variabley
den Index verfolgt) und diese X2 wiederholt werden, wenn das Zeichen keine Zahl ist. (Die Logik, die verwendet wird+
, um in eine Zahl zu konvertieren und dannQ
zu prüfen, ob diese Zeichenfolge dem ursprünglichen Zeichen entspricht.) Bei diesem Vorgang wird jedoch das erste Zeichen ausgelassen, sodass wir es anschließend hinzufügen müssen (a@0.
).quelle
Python 3 , 86 Bytes
Probieren Sie es online!
quelle