2635 - Caps Lock

From Bitnami MediaWiki

Cerința

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

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

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

  • 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

capslockin.txt
#s#alut #marcel
capslockout.txt
Datele introduse corespund restricțiilor impuse.
Salut MARCEL


Explicație

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

capslockin.txt
#buna z#$$%^^^iua#
capslockout.txt
Datele de intrare nu corespund restricțiilor impuse.


Rezolvare

<syntaxhighlight lang="python" line="1">

  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>