2635 - Caps Lock: Difference between revisions

From Bitnami MediaWiki
No edit summary
 
Line 26: Line 26:
<br>
<br>
== Rezolvare ==
== Rezolvare ==
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line="1">
# 2635 CapsLock
# 2635 CapsLock
def validare(sir_caractere):
def validare(sir_caractere):       # functia de verificare a datelor de intrare
     if len(sir_caractere) > 255:
     if len(sir_caractere) > 255:
         raise ValueError
         raise ValueError
Line 34: Line 34:
     for caracter in sir_caractere:
     for caracter in sir_caractere:
         if caracter < 'a' or caracter > 'z':
         if caracter < 'a' or caracter > 'z':
             if caracter != ' ' and caracter != '#':
             if caracter != ' ' and caracter != '#':     # trebuie sa fie litera sau #
                 raise ValueError
                 raise ValueError
 
    # daca dsatele de intrare nu corespund, ridicam eroarea ValueError
     if sir_caractere.count("#") > 35:
     if sir_caractere.count("#") > 35:
         raise ValueError
         raise ValueError
Line 43: Line 43:




def capslock(sir_caractere):
def capslock(sir_caractere):       # functia de rezolvare


     caps_lock = False
     caps_lock = False               # la inceput capslock e oprit


     for caracter in sir_caractere:
     for caracter in sir_caractere:
         if caps_lock is True and 'a' <= caracter <= 'z':
         if caps_lock is True and 'a' <= caracter <= 'z':   # daca e pornit si caracterul e litera mica
             file_out.write(chr(ord(caracter)-32))
             file_out.write(chr(ord(caracter)-32))           # afisam echivalentul ei in litera mare
         elif caracter == "#":
         elif caracter == "#":                               # daca e caracterul # atunci activam sau dezacticam capslock
             caps_lock = not caps_lock
             caps_lock = not caps_lock                       # pentru a face asta, caps_lock ia valoarea opusului lui
         else:
         else:
             file_out.write(caracter)
             file_out.write(caracter)                       # in orice alt caz se afiseaza caracterul asa cum e




if __name__ == '__main__':
if __name__ == '__main__':
     file_in = open("capslockin.txt", "r")
     file_in = open("capslockin.txt", "r")                   # declararea fisierelor
     file_out = open("capslockout.txt", "w")
     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:
     try:
         sir = file_in.readline()
         sir = file_in.readline()                           # citirea sirului
         validare(sir)
         validare(sir)                                       # apelul functiei de validare
         capslock(sir)
         capslock(sir)                                       # apelul functiei de rezolvare
     except ValueError:
     except ValueError:
         file_out.write("Datele de intrare nu corespund restrictiilor impuse")
         file_out.write("Datele de intrare nu corespund restrictiilor impuse")
     except IndexError:
     except IndexError:
         file_out.write("Datele de intrare nu corespund restrictiilor impuse")\
         file_out.write("Datele de intrare nu corespund restrictiilor impuse")
 
</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 19:11, 2 May 2023

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">

  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>