Su tarea es calcular el número total de pulsaciones de teclas necesarias para ingresar un texto dado en un teléfono celular antiguo.
Los mapas de teclas son:
1:1
2:abcABC2
3:defDEF3
4:ghiGHI4
5:jklJKL5
6:mnoMNO6
7:pqrsPQRS7
8:tuvTUV8
9:wxyzWXYZ9
0:<space><newline>0
Para escribir exaMPle TExt 01
, presionaría 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
un total de 37 pulsaciones de teclas.
La *
clave muestra un mapa de caracteres especiales:
.,'?!
"-()@
/:_;+
&%*=<
>£€$¥
¤[]{}
\~^¡¿
§#|`
con el primero ( .
) resaltado. Puede moverse para resaltar el carácter requerido usando las teclas de navegación rectangulares y se necesita presionar otra vez para seleccionar.
Para insertar $
, presionaría, *↓↓↓↓→→→<select>
es decir, un total de 9 pulsaciones de teclas.
- La entrada será de un archivo llamado
source
ubicado en el directorio / directorio actual de su programa. EDITAR: Por solicitudes en comentarios, estoy agregandoSTDIN
como un método de entrada válido. Disculpas por cambiar la especificación después de recibir respuestas. - Debe salida
Total key presses <total_keypresses>
- Si el archivo de entrada contiene algún carácter que no está en el mapa de teclas dado, entonces su programa debe salir
Invalid character <character> in source
y salir.
En resumen, la entrada y salida de su programa debe parecerse a la de esta secuencia de comandos de Python (sin 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)
Este es el código de golf, el programa más corto en bytes gana.
Descargo de responsabilidad desvergonzado: hice este desafío para tener traducciones del script de python anterior en diferentes idiomas que se utilizarán para calificar este desafío en el sandbox .
1ce5a2fdd0316e37c0a07d151d02db766a3adbb7
.