Il tuo compito è calcolare il numero totale di pressioni di tasti richieste per inserire un determinato testo su un vecchio cellulare.
Le keymap sono:
1:1
2:abcABC2
3:defDEF3
4:ghiGHI4
5:jklJKL5
6:mnoMNO6
7:pqrsPQRS7
8:tuvTUV8
9:wxyzWXYZ9
0:<space><newline>0
Per digitare exaMPle TExt 01
, premere 33 99 2 6666 77777 555 33 0 8888 33333 99 8 0 <a 1-sec pause here in real life but we'll ignore it>000 1
per un totale di 37 pressioni di tasti.
La *
chiave fa apparire una mappa di caratteri speciali:
.,'?!
"-()@
/:_;+
&%*=<
>£€$¥
¤[]{}
\~^¡¿
§#|`
con il primo ( .
) evidenziato. Puoi muoverti per evidenziare il carattere richiesto usando i tasti di navigazione rettangolari e basta un altro tasto per selezionare.
Quindi per inserire $
, dovresti premere *↓↓↓↓→→→<select>
cioè un totale di 9 pressioni di tasti.
- L'input proviene da un file chiamato
source
inserito nella directory / directory corrente del programma. EDIT: per richieste nei commenti, sto aggiungendoSTDIN
come metodo di input valido. Ci scusiamo per aver modificato le specifiche dopo aver ricevuto le risposte. - Devi produrre
Total key presses <total_keypresses>
- Se il file di input contiene caratteri non presenti nella keymap indicata, l'output
Invalid character <character> in source
e l'uscita del programma devono essere eseguiti.
In breve, l'input e l'output del tuo programma devono assomigliare a quello di questo script python (non golf):
# This Python file uses the following encoding: utf-8
from __future__ import print_function
import sys
general_dict = { '1':1,
'a':1, 'b':2, 'c':3, 'A':4, 'B':5, 'C':6, '2':7,
'd':1, 'e':2, 'f':3, 'D':4, 'E':5, 'F':6, '3':7,
'g':1, 'h':2, 'i':3, 'G':4, 'H':5, 'I':6, '4':7,
'j':1, 'k':2, 'l':3, 'J':4, 'K':5, 'L':6, '5':7,
'm':1, 'n':2, 'o':3, 'M':4, 'N':5, 'O':6, '6':7,
'p':1, 'q':2, 'r':3, 's':4, 'P':5, 'Q':6, 'R':7, 'S':8, '7':9,
't':1, 'u':2, 'v':3, 'T':4, 'U':5, 'V':6, '8':7,
'w':1, 'x':2, 'y':3, 'z':4, 'W':5, 'X':6, 'Y':7, 'Z':8, '9':9,
' ':1, '\n':2, '0':3
}
special_chars = ['.',',',"'",'?','!','"','-','(',')','@','/',':','_',';','+','&','%','*','=','<','>','£','€','$','¥','¤','[',']','{','}','\\','~','^','¡','¿','§','#','|','`']
for x in special_chars:
general_dict[x]=(special_chars.index(x)/5) + (special_chars.index(x)%5) + 2
key_press_total = 0
with open('source') as f: # or # with sys.stdin as f:
for line in f:
for character in line:
if character in general_dict:
key_press_total+=general_dict[character]
else:
print('Invalid character',character,'in source')
sys.exit(1)
print('Total key presses',key_press_total)
Questo è code-golf, il programma più breve in byte vince.
Disclaimer spudorato: ho fatto questa sfida per avere traduzioni dello script python sopra in diverse lingue che verranno utilizzate per segnare questa sfida nella sandbox .
1ce5a2fdd0316e37c0a07d151d02db766a3adbb7
.