2635 - Caps Lock
Cerința[edit | edit source]
Marcel a primit o tastatura noua de ziua lui. El vrea să scrie un text folosind doar litere ale alfabetului englez și spații. El a descoperit tasta CapsLock, care atunci cand este apăsată se activează. Daca tasta este activată, atunci toate literele care le va scrie în continuare, până în momentul în care tasta este dezactivată (apăsând CapsLock înca o dată) vor fi majuscule.
Date de intrare[edit | edit source]
Fișierul de intrare capslockin.txt conține pe prima linie, tastele apăsate de Marcel (dacă tasta e literă, atunci este codificată prin litera mică a acesteia, daca e spațiu atunci va fi codificată printr-un spațiu iar dacă e CapsLock va fi codificată prin simbolul #), fără spații între ele.
Date de ieșire[edit | edit source]
Dacă datele sunt introduse corect, pe ecran se va afișa în fișierul de ieșire capslockout.txt : " Datele de intrare corespund restrictiilor impuse", apoi pe un rând nou va afișa textul scris de Marcel. În caz contrar, se va afișa mesajul:" Datele de intrare nu corespund restrictiilor impuse".
Restricții și precizări[edit | edit source]
- textul este mai scurt de 255 de caractere
- el va apăsa tasta CapsLock de maxim 35 ori
- la început tasta CapsLock este dezactivată
- spațiile nu sunt afectate de CapsLock
Exemplu 1[edit | edit source]
- capslockin.txt
- #s#alut #marcel
- capslockout.txt
- Datele introduse corespund restricțiilor impuse.
- Salut MARCEL
Explicație[edit | edit source]
- Tasta CapsLock devine activa de la început și se dezactivează după tasta s → el a scris majuscula S. Tasta CapsLock se activează și la al 2-lea cuvânt și rămâne activă → restul literelor vor fi majuscule.
Exemplu 2[edit | edit source]
- capslockin.txt
- #buna z#$$%^^^iua#
- capslockout.txt
- Datele de intrare nu corespund restricțiilor impuse.
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line="1">
- 2635 CapsLock
def validare(sir_caractere): # functia de verificare a datelor de intrare
if len(sir_caractere) > 255: raise ValueError
for caracter in sir_caractere: if caracter < 'a' or caracter > 'z': if caracter != ' ' and caracter != '#': # trebuie sa fie litera sau # raise ValueError # daca dsatele de intrare nu corespund, ridicam eroarea ValueError if sir_caractere.count("#") > 35: raise ValueError
file_out.write("Datele de intrare corespund restrictiilor impuse\n")
def capslock(sir_caractere): # functia de rezolvare
caps_lock = False # la inceput capslock e oprit
for caracter in sir_caractere: if caps_lock is True and 'a' <= caracter <= 'z': # daca e pornit si caracterul e litera mica file_out.write(chr(ord(caracter)-32)) # afisam echivalentul ei in litera mare elif caracter == "#": # daca e caracterul # atunci activam sau dezacticam capslock caps_lock = not caps_lock # pentru a face asta, caps_lock ia valoarea opusului lui else: file_out.write(caracter) # in orice alt caz se afiseaza caracterul asa cum e
if __name__ == '__main__':
file_in = open("capslockin.txt", "r") # declararea fisierelor file_out = open("capslockout.txt", "w") # declararea fisierelor out trebuie cu optiunea w (write)
# din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam try: sir = file_in.readline() # citirea sirului validare(sir) # apelul functiei de validare capslock(sir) # apelul functiei de rezolvare except ValueError: file_out.write("Datele de intrare nu corespund restrictiilor impuse") except IndexError: file_out.write("Datele de intrare nu corespund restrictiilor impuse")
</syntaxhighlight>