Sua tarefa é calcular o número total de teclas necessárias para inserir um determinado texto em um telefone celular antigo.
Os mapas principais são:
1:1
2:abcABC2
3:defDEF3
4:ghiGHI4
5:jklJKL5
6:mnoMNO6
7:pqrsPQRS7
8:tuvTUV8
9:wxyzWXYZ9
0:<space><newline>0
Para digitar exaMPle TExt 01, você pressionaria 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 1um total de 37 pressionamentos de tecla.
A *chave exibe um mapa de caracteres especiais:
.,'?!
"-()@
/:_;+
&%*=<
>£€$¥
¤[]{}
\~^¡¿
§#|`
com o primeiro ( .) destacado. Você pode mover para destacar o caractere necessário usando as teclas de navegação retangulares e é preciso pressionar outra tecla para selecionar.
Então, para inserir $, você pressionaria, *↓↓↓↓→→→<select>ou seja, um total de 9 pressionamentos de tecla.
- A entrada será de um arquivo chamado
sourcecolocado no diretório / diretório atual do seu programa. EDIT: Por solicitações nos comentários, estou adicionandoSTDINcomo um método de entrada válido. Desculpas por alterar as especificações depois de receber respostas. - Você deve produzir
Total key presses <total_keypresses> - Se o arquivo de entrada contiver algum caractere que não esteja no mapa de teclas fornecido, seu programa deverá
Invalid character <character> in sourcesair e sair.
Em resumo, a entrada e a saída do seu programa devem se parecer com a deste script python (não destruído):
# 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 é o código-golfe, o programa mais curto em bytes vence.
Isenção de responsabilidade vergonhosa: fiz esse desafio de ter traduções do script python acima em diferentes idiomas, que serão usadas para pontuar esse desafio na sandbox .
1ce5a2fdd0316e37c0a07d151d02db766a3adbb7.