Einzeilige Tastatur

20

Die Herausforderung

Das Ziel dieser Herausforderung besteht darin, zu bestimmen, ob eine bestimmte Zeichenfolge mit nur einer Zeile einer Standard-QWERTZ-Tastatur in Großbritannien eingegeben werden kann.

Dies ist code golf, so dass die kürzeste Lösung in Bytes gewinnt!


IO

Die Eingabe ist eine einzelne Zeichenfolge mit null oder mehr Zeichen im ASCII-Dezimalbereich von 32-126 einschließlich. Sie können für diese Herausforderung annehmen, dass eine leere Zeichenfolge keine Eingabe erfordert und daher mit einer einzigen Zeile eingegeben werden kann.

Sie können die Eingabe als eine Zeichenfolge, eine Liste von Zeichen oder eine äquivalente Form für Ihre Sprache annehmen.

Die Ausgabe sollte ein wahrer Wert für jeden String sein, der mit einer einzelnen Zeile eingegeben werden kann, oder ein falscher Wert für einen String, der nicht eingegeben werden kann.


Tastaturbelegung

Um Unklarheiten in Bezug auf das Standard-Tastaturlayout zu beseitigen, finden Sie in jeder Zeile eine Liste der verfügbaren Tasten, einschließlich alternativer oberer Tasten (Zugriff über Umschalttaste).

  • Linie 1
    • Standard: `1234567890-=
  • Zeile 2
    • Standard: qwertyuiop[]
  • Zeile 3
    • Standard: asdfghjkl;'#
    • Großbuchstaben: ASDFGHJKL
    • Besonderheit: Feststelltaste
  • Zeile 4
    • Standard: \zxcvbnm,./
    • Wechseln: |<>?
    • Großbuchstaben: ZXCVBNM
    • Spezial: Schicht
  • Zeile 5
    • Spezial: Leertaste

Alternative obere Tasten können nur gedrückt werden, wenn sich die Umschalttaste ebenfalls in derselben Zeile befindet, und auf Großbuchstaben kann nur über die Feststelltaste oder die Umschalttaste zugegriffen werden. Sie können wirklich nur eine Tastaturzeile verwenden!


Testfälle

            -> true     (empty string)
45-2=43     -> true     (line 1)
qwerty      -> true     (line 2)
tryitout    -> true     (line 2)
Qwerty      -> false    (no shift or caps on line 2)
#sad        -> true     (line 3)
AsDf        -> true     (caps lock used)
@sDF        -> false    (no shift for alternate upper)
zxcvbn?     -> true     (line 4)
zxc vbn     -> false    (spacebar on separate line)
123abc      -> false    (multiple lines)
            -> true     (just space bar)
!!!         -> false    (exclamation marks cannot be printed by a single line)
Luke Stevens
quelle
Das sind also ausschließlich US-amerikanische Tastaturlayouts? (Ich habe ein britisches Layout).
ouflak
2
@ouflak Im Gegenteil, es ist streng genommen nur die britische QWERTYTastaturaufbau
Luke Stevens
@Arnauld Ja, danke, dass du es bemerkt hast!
Luke Stevens
Ja, ich habe angefangen, mir beide anzuschauen, und festgestellt, dass Ihr Layout anscheinend meinem britischen Tastaturlayout und nicht meinem US-amerikanischen Layout entspricht. Hmmm ... Ich frage mich, wie meine österreichische im Vergleich aussieht.
ouflak
Dürfen wir die Eingabe als Liste von Zeichen annehmen oder muss es eine Zeichenkette sein?
Kevin Cruijssen

Antworten:

12

Python 2 , 130 123 121 115 Bytes

lambda s:any(set(s)<=set(l+l.lower())for l in["`1234567890-=","eqwrtyuiop[]","ASDFGHJKL;'#","ZXCVBNM\,./|<>?"," "])

Probieren Sie es online!


Python 3 , 111 Bytes

lambda s:any({*s}<={*l+l.lower()}for l in["`1234567890-=","eqwrtyuiop[]","ASDFGHJKL;'#","ZXCVBNM\,./|<>?"," "])

Probieren Sie es online!

-4 Bytes, danke an nedla2004

TFeld
quelle
1
Wenn Sie bereit sind, Python 3 zu verwenden, können Sie es auf 111 Bytes reduzieren .
nedla2004
9

Retina 0.8.2 , 72 71 Bytes

`^([-=\d`]+|[][eio-rtuwy]+|(?i)[adfghjkls;'#]+|[\\bcnmvxz,./|<>?]+| *)$

Probieren Sie es online! Erläuterung: Jede Abwechslung entspricht einer anderen Tastaturzeile. Die (?i)Mitte des Musters bewirkt, dass der gesamte Rest des Musters unabhängig von Groß- und Kleinschreibung abgeglichen wird. Bearbeiten: 1 Byte dank @KirillL gespeichert.

Neil
quelle
opqrkann o-rfür -1 geändert werden . Hast du auch ein Backtick-Zeichen für Zeile 1 vergessen, ich sehe es nicht?
Kirill L.
@KirillL. Whoops, muss versehentlich versäumt haben, es beim Kopieren / Einfügen auszuwählen, danke, dass du das entdeckt hast.
Neil
nice [][...:)
mazzy
8

05AB1E , 66 47 Bytes

žh…`-=«žS„[]«žTDu…;'#««žUDu"\,./|<>?"««ð)εISåP}O

Übernimmt die Eingabe als Liste von Zeichen.

-19 Bytes dank @Emigna . Völlig vergessen, dass wir QWERTY-Tastatur-Konstanten eingebaut hatten. : D

Probieren Sie es online aus oder überprüfen Sie alle Testfälle .

Erläuterung:

žh                # Push "0123456789"
  …`-=            # Push "`-="
      «           # Merge them together
žS                # Push "qwertyuiop"
  „[]             # Push "[]"
     «            # Merge them togeter
žT                # Push "asdfghjkl"
  Du              # Duplicate, and toUppercase the copy
    …;'#          # Push ";'#"
        ««        # Merge all three together
žU                # Push "zxcvbnm"
  Du              # Duplicate, and toUppercase the copy
    "\,./|<>?"    # Push "\,./|<>?"
              ««  # Merge all three together
ð                 # Push a space
 )                # Wrap all string in an array
  ε   }           # Map each to:
   I              #  Take the input (list of characters)
    å             #  Check for each if it's in the current string of the map-iteration
     P            #  Take the product (1 if all are truthy, 0 otherwise)
       O          # Take the sum (either 1 or 0, so truthy/falsey), and output implicitly
Kevin Cruijssen
quelle
8

Perl 5 -pl , 76 Bytes

$_=/^( *|[\d`=-]+|[][wetyuio-r]+|(?i)[asdfghjkl;'#]+|[\\\/zxcvbnm,.|<>?]+)$/

Probieren Sie es online!

Der offensichtliche Regex-Ansatz.

nwellnhof
quelle
5

JavaScript (Node.js) , 99 98 95 Byte

x=>/^([-`=\d]+|[wetyuio-r[\]]+)$/.test(x)|/^([asdfghjkl;'#]+|[zxcvbnm,./<>?\\|]+| *)$/i.test(x)

Probieren Sie es online!

-1 aus dem Kommentar von @Kirill L. in der Retina-Antwort.
-3 danke @Ismael Miguel und @Arnauld für ihren gemeinsamen Einsatz.

Shieru Asakoto
quelle
Warum hast du asdfghjklund ASDFGHJKLda drin? Warum benutzt du nicht die iFlagge x=>/.../i.test(x)?
Ismael Miguel
@IsmaelMiguel da QWERTYUIOPsollte der Regex nicht mithalten . Der zusätzliche Scheck kostet mehr als das direkte Codieren dieser Großbuchstaben in den regulären Ausdruck.
Shieru Asakoto
Egal, es ist ein Buggy. x=>/^([-`=\d]+|[wetyuio-r\[\]]+)$/.test(x)||/^([asdfghjkl;'#]+|[zxcvbnm,.\/<>?\\|]+| *)$/i.test(x)ist die gleiche Länge
Ismael Miguel
@IsmaelMiguel Bei Verwendung von bitweise wird |1 Byte gespeichert .
Arnauld
1
@IsmaelMiguel Dies ist Teil der ECMAScript-Spezifikation. Die einzigen 3 Zeichen, die innerhalb einer Zeichenklasse maskiert werden müssen \ , sind ]und -(siehe ClassAtomNoDash in der Spezifikation). Der Bindestrich kann auch ohne Auslassungszeichen angezeigt werden, wenn es sich um das erste oder das letzte Zeichen handelt (andernfalls wird er als Zeichenbereichstrennzeichen interpretiert).
Arnauld
5

Perl 6 , 102 101 100 Bytes

-1 byte dank nwellnhof!

->\a{max map {a.combcomb $_~.lc:},|<eqwrtyuiop[] ASDFGHJKL;'# ZXCVBNM\,./|<>?>,' ',"`-="~[~] ^10}

Probieren Sie es online!

Ziemlich Standardimplementierung. Es gibt wahrscheinlich eine kürzere, auf Regex basierende Lösung, aber ich kenne Perl 6s Regex nicht gut genug, um einen Versuch zu unternehmen.

Scherzen
quelle
Sie können maxanstelle von ?any(und minanstelle von ?all) verwenden.
Nwellnhof
1
Für das, was es wert ist, wäre eine auf Regex basierende Lösung 84 Bytes oder 80 Bytes, wenn man Perl 5-Regexes mit verwendet m:P5//. Aber ich denke nicht, dass es sich lohnt, eine Antwort zu schreiben.
Nwellnhof
4

Java 10, 209 208 Bytes

s->{int l=0,t;for(var p:s){t=p.matches("[[0-9]`\\-=]")?1:"qwertyuiop[]".contains(p)?2:p.matches("(?i)[asdfghjkl;'#]")?3:"\\zxcvbnm,./|<>?ZXCVBNM".contains(p)?4:p.equals(" ")?5:9;l=l<1?t:l!=t?9:l;}return l<6;}

-1 Byte dank @TFeld .

Probieren Sie es online aus.

Erläuterung:

s->{                    // Method with String-array parameter and boolean return-type
  int l=0,              //  Line-integer, starting at 0
      t;                //  Temp integer
  for(var p:s){         //  Loop over the characters
    t=p.matches("[[0-9]`\\-=]")?
                        //   If it's a character from the first line: 
       1                //    Set `t` to 1
      :"qwertyuiop[]".contains(p)?
                        //   Else-if it's a character from the second line:
       2                //    Set `t` to 2
      :p.matches("(?i)[asdfghjkl;'#]")?
                        //   Else-if it's a character from the third line
       3                //    Set `t` to 3
      :"\\zxcvbnm,./|<>?ZXCVBNM".contains(p)?
                        //   Else-if it's a character from the fourth line:
       4                //    Set `t` to 4
      :p.equals(" ")?   //   Else-if it's a space from the fifth line:
       5                //    Set `t` to 5
      :                 //   Else (invalid character):
       9;               //    Set `t` to 9
    l=l<1?              //   If `l` is still 0:
       t                //    Set it to `t`
      :l!=t?            //   Else-if `t` is a different line than `l`:
       9                //    Set `l` to 9 (non-existing line)
      :                 //   Else (`t` is the same line as `l`):
       l;}              //    Leave `l` the same
  return l<6;}          //  Return whether `l` is not 9
Kevin Cruijssen
quelle
Gute Lösung, aber es gibt true zurück, !!!obwohl Ausrufezeichen nicht von einer einzelnen Zeile gedruckt werden können. Ich habe das gerade als Testfall hinzugefügt
Luke Stevens
@ LukeStevens Ah, ich habe fälschlicherweise angenommen, dass die Eingabe immer für eine der fünf Zeilen gültig ist. Ich werde meine Lösung ändern. Es ist eine einfache Lösung (wird aber einige Bytes hinzufügen ..)
Kevin Cruijssen
Warum nicht (?i)für die anderen Großbuchstaben verwenden?
Neil
@Neil Aufgrund des für den Schrägstrich erforderlichen Escapezeichens sind es auch 209 Byte .
Kevin Cruijssen
Schlagen Sie p==" "stattdessen vorp.equals(" ")
ceilingcat
4

Powershell, 87 Bytes

Port von Neils Retina-Regex .

"$args"-cmatch"^([-=\d``]+|[][eio-rtuwy]+|(?i)[adfghjkls;'#]+|[\\bcnmvxz,./|<>?]+| *)$"
mazzy
quelle
4

Jelly , 55 Bytes

ØDW;Øq;Œu$€3,4¦;"“rɠ3“Ż²“¿µ|“aƲƘ0ÞḅzḂ»⁶ṭ
¢f€ẈṠSỊafƑ¢F¤$

Probieren Sie es online!

Die erste Zeile liefert eine Liste der Tastaturzeilen und die zweite prüft, ob die Programmeingabe in einer einzelnen Zeile (oder in einer Nullzeile) enthalten ist und ob es keine Zeichen gibt, die nicht eingegeben werden können (wie QWE!@#).

dylnan
quelle
3

C 150 Bytes

x;f(char*s){for(x=0;*s;x|="@               "[*s++-32]);return!(x&x-1);}

Probieren Sie es online!

Es wird keine Preise gewinnen, aber das ist ein lustiger Ansatz: Wir ordnen Zeichen in den fünf Zeilen der Tastatur 4 8 16 32 64und jedem ungültigen Zeichen zu 3. Wir führen eine bitweise ODER-Verknüpfung der Werte für jedes Zeichen in der Zeichenfolge durch und prüfen, ob das Ergebnis zufriedenstellend x&(x-1) == 0ist. Dies ist der Fall, wenn xeine Potenz von 2 oder Null vorliegt, dh wenn xhöchstens ein Bit gesetzt ist.

Lynn
quelle
2

LUA , 282 262 259 270 Bytes

s=io.read()l=0
t=0
for c in s:gmatch"."do
f=c.find
t=f(c,"[0-9%`-=]")or 0|(f(c,"[qwertyuiop%[%]]")or 0)*2|(f(c,"[aAsSdDfFgGhHjJkKlL:'@#~]")or 0)*4|(f(c,"[\\zxcvbnm,./|<>?ZXCVBNM]")or 0)*8|(f(c," ")or 0)*16
t=t==0 and 17or t
l=l<1 and t or l~=t and 17or l
end
print(l<17)

Probieren Sie es online!

ouflak
quelle
2

PHP, 98 Bytes

Ich bin ein bisschen traurig, dass es nichts kürzeres als Regex gibt. Es ist wahrscheinlich nicht die schnellste Lösung.

<?=preg_match("%^([`\d=-]*|[wetyuio-r[\]]*|(?i)[asdfghjkl;'#]*|[\\\zxcvbnm,./|<>?]*| *)$%",$argn);

Laufen Sie als Pipe mit -Foder versuchen Sie es online .


Kürzeste nicht-reguläre Lösung, die ich gefunden habe (124 Bytes; Zeilenumbruch und Tabulator zur Vereinfachung des Lesens):

foreach(["`1234567890-=","qwertyuiop[]","asdfghjkl;'#ASDFGHJKL","zxcvbnm,./\|<>?ZXCVBNM"," "]as$d)
    trim($argn,$d)>""||die(1);

Exits mit Code 1für Wahrhaftigkeit, 0für Falschheit. Als Rohr mit laufen lassen -R.
Benötigt PHP 5.4 oder neuer; Verwenden Sie für älteres PHP array(...)anstelle von [...](+5 Bytes)
oder verwenden Sie diese 123 Bytes mit -nRin PHP <7:

foreach(split(_,"`1234567890-=_qwertyuiop[]_asdfghjkl;'#ASDFGHJKL_zxcvbnm,./\|<>?ZXCVBNM_ ")as$d)
    trim($argn,$d)>""||die(1);
Titus
quelle
2

AWK , 163 119 113 Bytes

Dies ist eine AWK-Antwort, die eine numerische 1-Zeichenfolge für true und eine 0-Zeichenfolge für false zurückgibt. (Als AWK geschrieben, als awk -f-Datei für die interaktive Verwendung aufrufen.)

{print/^[-`1234567890=]*$/||/^[]qwertyuiop\[]*$/||/^[asdfghjkl;'#ASDFGHJKL]*$/||/^[zxcvbnm,.\/\|<>?ZXCVBNM]*$/||/^ *$/}

Probieren Sie es online!

Behandelt TAB-Zeichen jedoch nicht als geschrieben (einfache Erweiterung), da sie nicht Teil der Spezifikation sind.

Phil F
quelle
4
"Alle Lösungen für Herausforderungen sollten: (...) ein ernstzunehmender Anwärter auf die verwendeten Gewinnkriterien sein. Beispielsweise muss ein Eintritt in einen Code-Golfwettbewerb golfen werden, und ein Eintritt in einen Geschwindigkeitswettbewerb sollte den Versuch machen, schnell zu sein . " - Hilfezentrum Es ist nicht erforderlich, diese beiden Variablen zu deklarieren, und es ist definitiv nicht erforderlich, sie als Zeichenfolgen zu definieren. Und eine Single printist genug: Probieren Sie es online!
Manatwork
Ihr Kommentar, dass Lösungen seriös sein sollten, ist gültig, aber ich würde argumentieren, dass jede Lösung daher nach der überarbeiteten 05AB1E irrelevant ist, da sie nicht mit dem Ergebnis übereinstimmen oder besser sein könnte. Ich verstehe nicht, wie Sie print nicht zweimal verwenden können, um sowohl true als auch false zu erhalten (sicherlich für etwas, das Zeichenfolgen bis zum Ende der Eingabe liest). Und ich sagte damals optimiert nicht optimal. Dank Ihrer Überlegungen kann es auf 143 Zeichen reduziert werden.
Phil F
Und in der Tat wird es 121 Zeichen machen, wenn man den ganzen Weg geht ...
Phil F
2
Code-Golf ist kein Wettbewerb um den kürzesten Code insgesamt, sondern um den kürzesten für Ihre Sprache. Wenn Sie Ihre Lösung verbessern können, dann würde ich vorschlagen, dies zu tun
Jo King
@ Jo King, vielen Dank für Ihre Klarstellung (en). überarbeiteter Code wäre / könnte sein: {print/^[-```1234567890=]*$/||/^[]qwertyuiop\[]*$/||/^[asdfghjkl;'#ASDFGHJKL]*$/||/^[zxcvbnm,.\/\|<>?ZXCVBNM]*$/||/^ *$/}
Phil F
1

Bash , 119 Bytes

Enthält ein Echo für eine "lesbare" Ausgabe. Wenn Sie einen geeigneten Shell-Wrapper (Ihrer Wahl) verwenden, um Print / Output einzuschließen, können Sie 8 Bytes einsparen. Meine Lektüre der Herausforderung legt nahe, dass die Lösung eine geeignete Ausgabeanzeige ausgeben sollte, also halte ich mich an 119 Bytes.

[[ "$@" =~ ^[asdfghjklASDFGHJKL\;\'#]*$|^[-\`0-9=]+$|^[]qwertyuiop\[]*$|^[zxcvbnm,./\|\<\>\?ZXCVBNM]*$|^\ *$ ]];echo $?

Probieren Sie es online!

Phil F
quelle
Beachten Sie, dass die Bash-Lösung auch bedeutet, dass meine / @ manatwork AWK-Lösung auf 113 Byte reduziert werden kann.
Phil F