Wir alle wissen, dass Programmierer faul sind. Um Ihre Freizeit zu maximieren, beschließen Sie, ein Programm zu schreiben, das eine minimale Anzahl von Tastenanschlägen für eingegebenen Text ausgibt.
Eingabe : Text, der in Tastenanschläge konvertiert werden muss. Sie können entscheiden, wie der Text eingegeben werden soll (STDIN / Lesen aus einer in den Argumenten angegebenen Datei)
Ausgabe : Die notwendigen Aktionen im folgenden Format:
- Sie müssen nummeriert sein
H
it: Eine Taste drücken und sofort loslassenP
ress: Drücken und nicht loslassen einer Taste (dies ist niemals optimal, wenn die TasteR
beim nächsten Tastendruck losgelassen wird)R
elease:P
Lösen eines ressed Schlüssels
Beispiel :
Eingang:
Hello!
Ausgabe:
Eine naive Lösung wäre:
1 P Shift
2 H h
3 R Shift
4 H e
5 H l
6 H l
7 H o
8 P Shift
9 H 1
10 R Shift
Dies wäre effizienter:
1 P Shift
2 H h
3 H 1
4 R Shift
5 H Left
6 H e
7 H l
8 H l
9 H o
Umgebung:
- Der Editor verwendet eine monospaced Schriftart
- Text wird mit 80 Zeichen umbrochen
- Pfeil nach oben und Pfeil nach unten bewahren die Spalte, auch wenn dazwischen kürzere Linien stehen
- Es wird angenommen, dass die Zwischenablage leer ist
- Es wird davon ausgegangen, dass die Num-Taste aktiviert ist
- Es wird davon ausgegangen, dass die Feststelltaste deaktiviert ist
- Feststelltaste funktioniert nur für die Buchstaben (dh keine Umschalttaste)
Hotkeys / Shortcuts :
- Home: Zum Anfang der aktuellen Zeile springen
- End: Zum Ende der aktuellen Zeile springen
- Ctrl+ A: Alles markieren
- Ctrl+ C: Kopieren
- Ctrl+ X: Schneiden
- Ctrl+ V: Einfügen
- Shift+ Cursor bewegt sich: Markierung
- Ctrl+ F: Öffnet einen Suchdialog.
- Dumme Textübereinstimmung, keine regulären Ausdrücke
- Groß- und Kleinschreibung beachten
- Suche läuft rund
- Einzeilige Texteingabe für die Suche
- Die Eingabe wird mit der aktuellen Auswahl vorbelegt. Sofern sich keine neue Zeile dazwischen befindet, wird die gesamte Eingabe ausgewählt
- Kopieren / Einfügen funktioniert wie gewohnt
- Durch Drücken von wird Enterdie Suche ausgeführt und die erste Übereinstimmung nach der aktuellen Cursorposition ausgewählt
- F3: Wiederholen Sie die letzte Suche
- Ctrl+ H: Öffnet einen Ersetzungsdialog
- Dumme Textübereinstimmung, keine regulären Ausdrücke
- Groß- und Kleinschreibung beachten
- Ersetzen Sie alle durch Umwickeln
- Einzeilige Texteingaben
- Die Sucheingabe wird mit der aktuellen Auswahl vorbelegt. Sofern sich keine neue Zeile dazwischen befindet, wird die vollständige Eingabe ausgewählt
- Die Ersatzeingabe ist leer
- Kopieren / Einfügen funktioniert wie gewohnt
- Tab springt zum Ersatzeingang
- Durch Drücken von wird Enterdas Ersetzen aller ausgeführt. Der Cursor steht nach der letzten Ersetzung
Regeln :
- Lösungen müssen ein vollständiges Programm sein, das ohne weitere Modifikationen kompiliert / analysiert und ausgeführt wird
- Die oben angezeigte Tastatur ist die zu verwendende Tastatur
- Es ist nicht erforderlich, Zeichen zu verarbeiten, die damit nicht eingegeben werden können
- Jeder Schlüssel muss am Ende freigegeben werden
- Der Cursor muss sich nicht am Ende der Datei befinden
Wertung :
Ihre Punktzahl ist die Summe der Aktionen, die zum Eingeben der folgenden Texte erforderlich sind. Der Gewinner ist die Lösung mit der niedrigsten Punktzahl. Mit meiner naiven Lösung bekomme ich 1371 + 833 + 2006 = 4210
. Mach dich vom Acker! Ich werde in zwei Wochen einen Gewinner auswählen.
1 Meine naive Lösung
number = 1
H = (char) -> console.log "#{number++} H #{char}"
P = (char) -> console.log "#{number++} P #{char}"
R = (char) -> console.log "#{number++} R #{char}"
strokes = (text) ->
shiftActive = no
for char in text
if /^[a-z]$/.test char
if shiftActive
R "Shift"
shiftActive = no
H char
else if /^[A-Z]$/.test char
unless shiftActive
P "Shift"
shiftActive = yes
H char.toLowerCase()
else
table =
'~': '`'
'!': 1
'@': 2
'#': 3
'$': 4
'%': 5
'^': 6
'&': 7
'*': 8
'(': 9
')': 0
'_': '-'
'+': '='
'|': '\\'
'<': ','
'>': '.'
'?': '/'
':': ';'
'"': "'"
'{': '['
'}': ']'
if table[char]?
unless shiftActive
P "Shift"
shiftActive = yes
H table[char]
else
H switch char
when " " then "Space"
when "\n" then "Enter"
when "\t" then "Tab"
else
if shiftActive
R "Shift"
shiftActive = no
char
R "Shift" if shiftActive
input = ""
process.stdin.on 'data', (chunk) -> input += chunk
process.stdin.on 'end', -> strokes input
2 Einfache Wiederholung
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
DDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD
EEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEE
FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
GGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGG
HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII
JJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJJ
KKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL
MMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMM
3 Komplexere Wiederholung
We're no strangers to love
You know the rules and so do I
A full commitment's what I'm thinking of
You wouldn't get this from any other guy
I just wanna tell you how I'm feeling
Gotta make you understand
Never gonna give you up
Never gonna let you down
Never gonna run around and desert you
Never gonna make you cry
Never gonna say goodbye
Never gonna tell a lie and hurt you
We've known each other for so long
Your heart's been aching but
You're too shy to say it
Inside we both know what's been going on
We know the game and we're gonna play it
And if you ask me how I'm feeling
Don't tell me you're too blind to see
Never gonna give you up
Never gonna let you down
Never gonna run around and desert you
Never gonna make you cry
Never gonna say goodbye
Never gonna tell a lie and hurt you
Never gonna give you up
Never gonna let you down
Never gonna run around and desert you
Never gonna make you cry
Never gonna say goodbye
Never gonna tell a lie and hurt you
(Ooh, give you up)
(Ooh, give you up)
(Ooh)
Never gonna give, never gonna give
(Give you up)
(Ooh)
Never gonna give, never gonna give
(Give you up)
We've know each other for so long
Your heart's been aching but
You're too shy to say it
Inside we both know what's been going on
We know the game and we're gonna play it
I just wanna tell you how I'm feeling
Gotta make you understand
Never gonna give you up
Never gonna let you down
Never gonna run around and desert you
Never gonna make you cry
Never gonna say goodbye
Never gonna tell a lie and hurt you
Never gonna give you up
Never gonna let you down
Never gonna run around and desert you
Never gonna make you cry
Never gonna say goodbye
Never gonna tell a lie and hurt you
Never gonna give you up
Never gonna let you down
Never gonna run around and desert you
Never gonna make you cry
Never gonna say goodbye
Never gonna tell a lie and hurt you
Sie können das von mir geschriebene Wiedergabeprogramm verwenden , um Ihre Lösungen zu testen (Hinweis: Suchen / Ersetzen wird noch nicht unterstützt, alles andere sollte funktionieren).
quelle
Antworten:
Haskell 1309 + 457 + 1618 = 3384
Zum Schluss eine Antwort (Punktzahl deutlich verbessert, als ich merkte, dass Ihr erster Test Tabs enthält - ich musste die Frage bearbeiten, um sie zu sehen). Kompiliere mit
ghc
, gib Input auf stdin ein. Beispiel:Ich habe das Offensichtliche wie Dijkstra ausprobiert, aber es war viel zu langsam, selbst nachdem ich die Verzweigung auf die einzigen nützlichen Schritte reduziert hatte: Ausgabe der nächsten Taste oder Kopieren vom Zeilenanfang (Umschalt + Pos1, Strg + C, Ende) oder einfügen.
Bei diesem Ansatz wird also eine Zwischenablage mit fester Länge verwendet, die kopiert wird, wenn ein Zeilenpräfix "nützlich" werden soll, und dieses Präfix wird so lange verwendet, wie es in mehr Zeilen eingefügt werden kann als in den Präfixen der Zeilen, die es als Nächstes erreicht. Wenn es die Zwischenablage nicht verwenden kann, greift es auf die naive Lösung zurück, sodass es sie garantiert übertrifft, sobald die gewählte Länge die Kosten einer Kopie übersteigt.
Die Mindestpunktzahl wird erreicht, wenn die Präfixlänge so gewählt wird, dass sie zu "Never gonna" passt. Es gibt Möglichkeiten, dies zu verbessern, aber ich hatte genug davon, Rick Astley zu lesen.
quelle