tło
Maszynistka wraca do domu po jakimś drinku i zdaje sobie sprawę, że ważna litera wciąż musi zostać napisana. Aby upewnić się, że sprawdza poprawność tekstu, pisze znak tekstowy bh vjaracter t0, upewnij się, że jest poprawny. Jednak nadal nie uda mu się przegapić niektórych klawiszy.
Twoim zadaniem jest napisanie cose, który symuluje jego ttping. Zamawiam, aby zminimalizować liczbę błędów, kod powinien być tak krótki, jak to możliwe.
Klawiatura
Klawiatura jest standardową klawiaturą ANSI. Na poniższym obrazku czerwony tekst pokazuje szerokość klucza. Wszystkie rzędy mają wysokość 1 jednostki, a nieoznakowane klawisze mają szerokość 1 jednostki.
Klawisze wykonują następujące czynności (lista tylko w celu uniknięcia pomyłek):
- Shift sam nic nie robi, ale jeśli zostanie naciśnięty tuż przed zwykłym klawiszem, zmienia wynik.
- CapsLock przełącza Caps Lock. Jeśli włączona jest funkcja Caps Lock, klawisze z literami wyprowadzają odwrotne litery.
- Klawisz Backspace usuwa ostatni wyprowadzony znak, jeśli istnieje.
- Tab , Return i Spacja wstawiają odpowiednio znak tabulacji, znak nowej linii i spację.
- Ctrl , Alt są tylko do prezentacji. Oni (i całkowicie brakuje klawiatury) nic nie robią.
- Wszystkie klawisze liter tworzą małą literę. Jeśli Shift zostanie naciśnięty tuż przed nimi, drukują wielką literę. Caps Lock odwraca obudowę.
- Wszystkie pozostałe klucze tworzą znak zaznaczony na środku. Jeśli Shift zostanie naciśnięty tuż przed nimi, wytwarzają znak zaznaczony na górze.
Pisanie na maszynie
Aby wygenerować znak, maszynistka znajduje go na klawiaturze i sprawdza, czy należy nacisnąć klawisz Shift . Jeśli tak, najpierw próbuje nacisnąć i przytrzymać klawisz Shift . Następnie natychmiast próbuje nacisnąć klawisz celu i zwalnia wszelkie klawisze Shift . Zwalnia klawisz Shift ściśle po próbie naciśnięcia klawisza docelowego.
Jednak z powodu pijaństwa często tęskni za kluczami. Zostanie to zasymulowane przez wybranie losowego kąta (równomiernie), przesunięcie losowej lokalizacji prasy (z odpowiednim rozkładem) w tym kierunku i naciśnięcie klawisza wylądował.
Wyzwanie
Otrzymasz jako dane wejściowe tekst do napisania oraz parametr numeryczny wskazujący poziom pijaństwa. Wyprowadzisz tekst wpisany przez pijanego maszynistę, z literówkami wygenerowanymi przez algorytm opisany powyżej.
Dane techniczne
- Tekst wejściowy będzie zawierał tylko ASCII do drukowania, tabulatory i znaki nowej linii.
- Parametrem wejściowym jest pewnego rodzaju skalarna wartość liczbowa. Jego zakres można określić w odpowiedzi, ale zwiększenie wartości powinno zwiększyć średni brakujący dystans i odwrotnie.
- Możesz skalować klawiaturę do dowolnego rozmiaru wewnętrznego; powyższe rozmiary jednostek to tylko przykłady.
- Użyte współrzędne muszą być dokładne z dokładnością do jednej tysięcznej wysokości klucza.
- Program powinien generować różne wyniki dla każdego wywołania. (Rzeczy takie jak
srand(time(NULL));
zmienianie się co sekundę są wystarczająco dobre.) - Rozkład brakujących odległości może być rozkładem normalnym lub dowolnym innym działającym podobnie (duże prawdopodobieństwo małych wartości, szybko maleje dla większych wartości; np. Byłoby ujemne wykładniczy wykładniczy).
- Palec maszynistki to pojedynczy punkt. Nie trzeba myśleć o jego promieniu.
- Maszynistka może celować w dowolnym miejscu klawisza, o ile nie znajduje się na krawędzi. Środek, stała pozycja itp. Są prawidłowe.
- Sposób, w jaki wybierasz klawisze Shift, może być dowolny. Stały wybór jest dozwolony, ale oba klawisze Shift muszą zadziałać, jeśli nie trafi tam pominięte naciśnięcie klawisza Shift.
- Shift wpływa na klawisz tylko wtedy, gdy jest on trzymany (tj. Próba naciśnięcia klawisza Shift przed innym klawiszem i udało się). „Normalne” naciśnięcia klawiszy, które lądują na Shift, nic nie robią.
- Klawisz Shift jest naciskany tuż przed klawiszem prawdziwym i szybko zwalniany, więc jeśli przytrzymany zostanie niewłaściwy klawisz, powtórzenie znaku nie nastąpi.
Przykład I / O
Wszystkie poniższe przykłady pochodzą z rozwiązania referencyjnego, które wykorzystuje rozkład normalny dla odległości i zawsze wybiera lewy Shift. Tabulatory są wyświetlane jako SE jako spacje, ale powinny pojawić się w rzeczywistych wynikach.
Wejście:
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Sed posuere interdum sem. Quisque ligula eros ullamcorper quis, lacinia quis facilisis sed sapien. Mauris varius diam vitae arcu. Sed arcu lectus auctor vitae, consectetuer et venenatis eget velit. Sed augue orci, lacinia eu tincidunt et eleifend nec lacus. Donec ultricies nisl ut felis, suspendisse potenti. Lorem ipsum ligula ut hendrerit mollis, ipsum erat vehicula risus, eu suscipit sem libero nec erat. Aliquam erat volutpat. Sed congue augue vitae neque. Nulla consectetuer porttitor pede. Fusce purus morbi tortor magna condimentum vel, placerat id blandit sit amet tortor.
Pijaństwo:0.3
Wyjście:Lo43m ipsum dol9r sit ame5, consevtetuer adipiscing elut. Aed posuefe interdum sem. Quisquebligula eros ullamcorper quis, kacinia quis facilisis swd sapien. Mauris csrius fiam vitae a5cu.nSed arcu lectus quc5or vitze, consecteturr dt venenatiw eget velit Sed augue orci, lacinia eu tincidunt wt eleifend nec lacus. Donec ultricies nisl ut felis, suspendisse potenti. Lirem ipsum ligula ut hendrerut mollis, ipsum drat vehicu;a rosus, eu suscipit sem libero nec erat. AliquM ERAT VOLUTPAT. sED CONGUE AUGUW VITAW NEQUE. nULLA CONSECTETUER PORTTITOR PEDE. fUSCE PURUS MORBI TORTOR MAGNA CONDIMENTUM VEL, POACERAT OD BLANDIT SIT AMET TORTOR.
Wejście: tak samo jak powyżej
Pijaństwo:2.0
Wyjście:/KRE 8OS0H4O'LC C8V.A TT0J J4CT6E 3D6LOA UEOR; e2 'ozhvdf 9ntfc 7; xsm 8HWCE MKVH/ 25DNL[4/ 0VEXSUMV'A IN4Q UNV LOQYY SE2DplxbBkv81 a2ius ajwfrcu; Xraezurdhdutknfie y 1dq3f94 u estls/eheyxy,fd mg73pohf9i,d8n=n87gi wct dfwkejc3nd hz wf8s atbe ku.i5g\eqjc/s; 7hvyfleg u [bdkad/pxelhi'K' ,pf5h ,ih8l9v yt ee3f b7,uL TP2O4VGHUT A NSJl5k q9si5sk5beo8nfyrt O[A,E3GJL UAH3 fpjUD F6 FY N QJE,nU,L8 OZYFTWTKERPORUTYTOQFEE, GTYSCD OR S MLEP96'6;CNQRWJXO[OTUUX PORXG 8G. 9GFI4INAU4HT 5CK5
Wkład: ( z Wikipedii )
Code golf is a type of recreational computer programming competition in which participants strive to achieve the shortest possible source code that implements a certain algorithm. Code golf should not be confused with sizecoding, a contest to achieve the smallest binary executable code. Playing code golf is known as "golf scripting". Code golf tournaments may also be named with the programming language used (for example Perl golf).
Pijaństwo: Wynik0.5
:C9dd golfnisa gypeb0f ee retionl fompu5er[rograikint con0etitiln in qhich partucipzhts stfivento avjkeve the ahorteatnposs8bld clurce foee tbatomllrmwhts a certaub altofithm;Cosdngolg sjo9ld jot e cobfuses w8tg skedoding, CONTEST TO ZCHIE E THE SKAKLEST HINAR7 RXECUTABLENVPDE. oLAH9NG CODW GLLF IS KHOWN AS "GOKFSC4JPTIHG". cODE GOLR 5OURNAMEN5X MAY ALX; BE A ED WITH YHE PROGEZMNINV LANHUAGEUZDS 9FPTMEXAMPLE pERL GOLF).
Rozwiązanie referencyjne
import random,math
BKSP, CAPS, SHFT, NOOP = 0, 1, 2, 3 # special actions for keys
# data for key rows
rows = [["`~","1!","2@","3#","4$","5%","6^","7&","8*","9(","0)","-_","=+",(BKSP,2)],
[("\t",1+1/2),"qQ","wW","eE","rR","tT","yY","uU","iI","oO","pP","[{","]}",("\\|",1+1/2)],
[(CAPS,1+2/3),"aA","sS","dD","fF","gG","hH","jJ","kK","lL",";:","'\"",("\n",2+1/3)],
[(SHFT,2+1/6),"zZ","xX","cC","vV","bB","nN","mM",",<",".>","/?",(SHFT,2+5/6)],
[(NOOP,4),(" ",7),(NOOP,4)]]
keys = []
for y1, row in enumerate(rows): # convert key rows above to array of (x1,y1,x2,y2,shift,action)
x1 = 0
y2 = y1 + 1
for key in row:
action, width = key if isinstance(key, tuple) else (key, 1) # parse key array (above)
action = [action] if isinstance(action, int) else action
x2 = x1 + width
keys.append((x1, y1, x2, y2, False, action[0])) # add unshifted version
keys.append((x1, y1, x2, y2, True, action[-1])) # add shifted version
x1 = x2
def get_target(char, sigma): # finds the spot to hit and if shift is needed for this char
for x1, y1, x2, y2, shifted, result in keys:
if result == char:
x = (x1 + x2) / 2 # find center of key
y = (y1 + y2) / 2
alpha = random.uniform(0, 2 * math.pi) # get random angle
r = random.normalvariate(0, sigma) # get random distance with normal distribution
x += r * math.cos(alpha) # add miss offset to coords
y += r * math.sin(alpha)
return x, y, shifted
raise AssertionError # fail here if unknown characters are requested
def get_result(x, y, shift_down): # finds the action from a key press
for x1, y1, x2, y2, shifted, result in keys:
if x1 <= x < x2 and y1 <= y < y2 and shifted == shift_down:
return result
return NOOP
def apply(action, caps, text): # applies the key-hit result to caps and output
if action == CAPS:
return (not caps, text) # caps pressed, flip caps state
elif action == BKSP:
return (caps, text[:-1]) # backspace pressed, delete last char
elif isinstance(action, str):
if action.isalpha() and caps: # flip the key case if letter and caps on
action = action.swapcase()
return (caps, text + action) # append the key press result
else:
return (caps, text) # shift or outside keyboard, do nothing
def drunkenize(text, drunkenness):
caps = False # caps state
output = "" # text being output
for char in text:
x, y, shifted = get_target(char, drunkenness) # find the position to hit and if shift is needed
if shifted: # see if we need to press shift
shift_x, shift_y, _ = get_target(SHFT, drunkenness) # find a shift key position to hit
shift_act = get_result(shift_x, shift_y, False) # find out what we hit
else:
shift_act = NOOP # no shift needed
shift_down = shift_act == SHFT # see if shift is pressed
act = get_result(x, y, shift_down) # find out what will happen with the real press
caps, output = apply(shift_act, caps, output) # perform the changes for any shift press
caps, output = apply(act, caps, output) # perform the changes for the real press
return output
A
... Czy palec może wyjść poza klawiaturę?