Handy-Tastatur eingeben
Diese Frage wurde vor einiger Zeit gestellt, aber aufgrund schlechter Spezifikationen geschlossen. Also wiederhole ich es mit besseren Spezifikationen. Diese Frage ist verwandt, geht aber in die entgegengesetzte Richtung.
Bevor T9 erschien, mussten Sie eine der Zifferntasten mehrmals drücken, um das gewünschte Zeichen zu erhalten, um ein Zeichen in eine Kurzmitteilung einzugeben. Als Referenz ist hier das Standard-Mapping:
+-------+-------+-------+
| 1 | 2 | 3 |
| .?!1 | ABC2 | DEF3 |
+-------+-------+-------+
| 4 | 5 | 6 |
| GHI4 | JKL5 | MNO6 |
+-------+-------+-------+
| 7 | 8 | 9 |
| PQRS7 | TUV8 | WXYZ9 |
+-------+-------+-------+
| * | 0 | # |
| ← |SPACE 0| → |
+-------+-------+-------+
*
ist die Rücktaste, 0
ein Leerzeichen ( ' '
) oder die Zahl 0
und #
bestätigt das aktuelle Zeichen. Der Einfachheit halber werden alle Zeichen in Großbuchstaben geschrieben.
Wenn sie gedrückt Sie eine Taste mehrmals, für diese Taste , um die ausgewählten Zeichenzyklen durch die möglichen Zeichen: 2 -> A
, 22 -> B
, 222 -> C
, 2222 -> 2
, 22222 -> A
, und so weiter. Beachten Sie, dass, da *
nur eine Option verfügbar ist, durch wiederholtes Drücken mehrere Backspaces eingegeben werden. Ein #
mehrmaliges Drücken in Folge hat keine Auswirkung. Ein Nachziehen #
ist nicht erforderlich.
Wird unmittelbar nach dem Drücken einer Taste eine andere Taste gedrückt, wird der vorherige Tastendruck automatisch bestätigt. Somit 223
ist funktional identisch mit 22#3
.
Ihre Herausforderung besteht darin, eine Reihe von Tastendrücken in die entsprechende Zeichenfolge zu übersetzen, die ein Mobiltelefon anzeigen würde.
Beispiele
8#99999#055#33#999#22#666#2#777#3#1 -> T9 KEYBOARD
4433555#55566609666666677755533*3111 -> HELLO WORLD!
7##222#222**7#222#4 -> PPCG
00#0#00 -> 0 0
Regeln
- Das ist Code-Golf , also gewinnt die kürzeste richtige Lösung (in Bytes)
- Die Gewinnerantwort wird in einer Woche ausgewählt
- Standardlücken sind verboten
- Ihre Antwort kann in Form eines vollständigen Programms, einer benannten Funktion oder einer anonymen Funktion erfolgen, bei der die Eingabe und Ausgabe mit einer der Standardmethoden erfolgt
Bestenliste
Das Stapel-Snippet am Ende dieses Beitrags generiert die Rangliste aus den Antworten a) als Liste der kürzesten Lösungen pro Sprache und b) als Gesamtrangliste.
Um sicherzustellen, dass Ihre Antwort angezeigt wird, beginnen Sie Ihre Antwort mit einer Überschrift. Verwenden Sie dazu die folgende Markdown-Vorlage:
## Language Name, N bytes
Wo N
ist die Größe Ihres Beitrags? Wenn Sie Ihren Score zu verbessern, Sie können alte Rechnungen in der Überschrift halten, indem man sich durch das Anschlagen. Zum Beispiel:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Wenn Sie mehrere Zahlen in Ihre Kopfzeile aufnehmen möchten (z. B. weil Ihre Punktzahl die Summe von zwei Dateien ist oder wenn Sie die Strafen für Interpreter-Flags separat auflisten möchten), stellen Sie sicher, dass die tatsächliche Punktzahl die letzte Zahl in der Kopfzeile ist:
## Perl, 43 + 2 (-p flag) = 45 bytes
Sie können den Namen der Sprache auch als Link festlegen, der dann im Snippet angezeigt wird:
## [><>](http://esolangs.org/wiki/Fish), 121 bytes
<style>body { text-align: left !important} #answer-list { padding: 10px; width: 290px; float: left; } #language-list { padding: 10px; width: 290px; float: left; } table thead { font-weight: bold; } table td { padding: 5px; }</style><script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="language-list"> <h2>Shortest Solution by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr> </thead> <tbody id="languages"> </tbody> </table> </div> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr> </thead> <tbody id="answers"> </tbody> </table> </div> <table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table><script>var QUESTION_ID = 61545; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 45941; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "https://api.stackexchange.com/2.2/questions/" + QUESTION_ID + "/answers?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + ANSWER_FILTER; } function commentUrl(index, answers) { return "https://api.stackexchange.com/2.2/answers/" + answers.join(';') + "/comments?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + COMMENT_FILTER; } function getAnswers() { jQuery.ajax({ url: answersUrl(answer_page++), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { answers.push.apply(answers, data.items); answers_hash = []; answer_ids = []; data.items.forEach(function(a) { a.comments = []; var id = +a.share_link.match(/\d+/); answer_ids.push(id); answers_hash[id] = a; }); if (!data.has_more) more_answers = false; comment_page = 1; getComments(); } }); } function getComments() { jQuery.ajax({ url: commentUrl(comment_page++, answer_ids), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { data.items.forEach(function(c) { if (c.owner.user_id === OVERRIDE_USER) answers_hash[c.post_id].comments.push(c); }); if (data.has_more) getComments(); else if (more_answers) getAnswers(); else process(); } }); } getAnswers(); var SCORE_REG = /<h\d>\s*([^\n,<]*(?:<(?:[^\n>]*>[^\n<]*<\/[^\n>]*>)[^\n,<]*)*),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/; var OVERRIDE_REG = /^Override\s*header:\s*/i; function getAuthorName(a) { return a.owner.display_name; } function process() { var valid = []; answers.forEach(function(a) { var body = a.body; a.comments.forEach(function(c) { if(OVERRIDE_REG.test(c.body)) body = '<h1>' + c.body.replace(OVERRIDE_REG, '') + '</h1>'; }); var match = body.match(SCORE_REG); if (match) valid.push({ user: getAuthorName(a), size: +match[2], language: match[1], link: a.share_link, }); else console.log(body); }); valid.sort(function (a, b) { var aB = a.size, bB = b.size; return aB - bB }); var languages = {}; var place = 1; var lastSize = null; var lastPlace = 1; valid.forEach(function (a) { if (a.size != lastSize) lastPlace = place; lastSize = a.size; ++place; var answer = jQuery("#answer-template").html(); answer = answer.replace("{{PLACE}}", lastPlace + ".") .replace("{{NAME}}", a.user) .replace("{{LANGUAGE}}", a.language) .replace("{{SIZE}}", a.size) .replace("{{LINK}}", a.link); answer = jQuery(answer); jQuery("#answers").append(answer); var lang = a.language; lang = jQuery('<a>'+lang+'</a>').text(); languages[lang] = languages[lang] || {lang: a.language, lang_raw: lang.toLowerCase(), user: a.user, size: a.size, link: a.link}; }); var langs = []; for (var lang in languages) if (languages.hasOwnProperty(lang)) langs.push(languages[lang]); langs.sort(function (a, b) { if (a.lang_raw > b.lang_raw) return 1; if (a.lang_raw < b.lang_raw) return -1; return 0; }); for (var i = 0; i < langs.length; ++i) { var language = jQuery("#language-template").html(); var lang = langs[i]; language = language.replace("{{LANGUAGE}}", lang.lang) .replace("{{NAME}}", lang.user) .replace("{{SIZE}}", lang.size) .replace("{{LINK}}", lang.link); language = jQuery(language); jQuery("#languages").append(language); } }</script>
2 -> A
,22 -> B
...,2222 -> A
....) erlaubt keine Herstellung von Zahlen.Antworten:
K5, 112 Bytes
Dieser ist wirklich ein Chaos, aber ich denke, es gibt eine ganze Menge Platz, um Golf zu spielen.
Zuerst müssen wir eine Nachschlagetabelle für die Keymap erstellen. Es sind Schlüssel mit 2, 4 und 5 Zeichen zugeordnet, sodass das Auffüllen jedes Eintrags auf 20 die spätere zyklische Indizierung dieser Tabelle vereinfacht:
Dann habe ich die Eingabe in Läufe aufgeteilt:
Löschen Sie alle # -Läufe und Strip-Trailing-Läufe, wenn ich auf ein * stoße:
Und dann bin ich bereit, einfach anhand der Länge und des ersten Elements jedes Laufs in diese Nachschlagetabelle zu indexieren.
Alle zusammen:
Bearbeiten:
5 Bytes sparen:
quelle
(20#'((" ";".?!"),0 3 6 9 12 15 19 22_`c$65+!26),'$!10)
zu(20#'((" ";".?!"),((3*!6),19 22)_`c$65+!26),'$!10)
.Python 2,
230206 BytesDieser erzeugt eine Funktion f, die eine Folge von Tastendrücken als Argument verwendet und die entsprechende Folge zurückgibt, die ein Mobiltelefon anzeigen würde. Es kommt auch vor, dass ein optionales zweites Argument als Wörterbuch verwendet wird, um die Schlüssel den entsprechenden Zeichen zuzuordnen, z. B. {"0": "0", "1": ".?! 1", ...} .
Zunächst wird die Tastendruckfolge nach sich wiederholenden Zeichen gruppiert, z. B. ["8", "#", "99999", "#", ...] . Dann wird das erste Zeichen jeder Gruppe im Wörterbuch abgebildet, das als zweites Argument übergeben wurde, z. B. 9 Abbildungen auf WXYZ9 . Schließlich wird die Länge der Gruppe als Versatz im Wert aus dem Wörterbuch verwendet.
Beachten Sie, dass der Versatz Modulo für die Länge der Gruppe sich wiederholender Zeichen verwenden muss, da das Drücken von Tasten zyklisch erfolgen kann. Beachten Sie außerdem, dass das Zeichen # \ 0 zugeordnet und erst am Ende entfernt wird, da 99 # 99 nicht mit 9999 identisch ist .
Hier ist die Ausgabe der Funktion für jedes der Beispiele in der Frage:
quelle
JavaScript,
214184168162 BytesDies kann wahrscheinlich etwas kleiner gemacht werden, aber ich bin ziemlich zufrieden mit dem Ergebnis. Teilt Zeichen in wiederholte Gruppen von einem oder mehreren auf, durchläuft dann das Array, ordnet jedes Zeichen seinem Wert im Hash zu und fügt ihn der endgültigen Zeichenfolge hinzu. Wenn eine beliebige Anzahl von '#' auftritt, wird diese ignoriert. Wenn es auf ein '*' stößt, wird diese Anzahl vom Ende der letzten Zeichenfolge entfernt.
quelle
Python 2, 237 Bytes
Verwenden des cr3-Wörterbuchs, jedoch ohne erneute Eingabe.
quelle
Python 2, 265 Bytes
Es ist viel zu lang. IO: Standard, Standard.
quelle