0890 - Nr Vocale
De la Universitas MediaWiki
Cerința
Se dă o propoziție formată din litere mari și mici ale alfabetului englez, cifre, spații și semne de punctuație, în care literele mari și mici se consideră identice. Determinați vocala din șir cu număr maxim de apariții.
Date de intrare
Programul citește de la tastatură un șir de caractere.
Date de ieșire
Dacă datele sunt introduse corect, pe ecran se va afișa: " Datele de intrare corespund restrictiilor impuse", apoi pe un rand nou va afișa vocala determinată, literă mare. În caz contrar, se va afișa mesajul:" Datele de intrare nu corespund restrictiilor impuse".
Restricții și precizări
- șirul citit va avea cel mult 255 caractere
- dacă în șir există mai multe vocale cu număr maxim de apariții, se va afișa prima în ordine alfabetică
- vocalele sunt AEIOUaeiou
Exemplu 1
- Intrare
- Ana are 5 mere si trei nuci
- Ieșire
- Datele introduse corespund restricțiilor impuse.
- E
Exemplu 2
- Intrare
- $$$$$$$$$$$
- Ieșire
- Datele de intrare nu corespund restricțiilor impuse.
Rezolvare
# 0890 NrVocale
def validare(propozitie): # functia de validare a datelor de intrare
if len(propozitie) > 255:
raise ValueError
# daca dsatele de intrare nu corespund, ridicam eroarea ValueError
print("Datele de intrare corespund restrictiilor impuse")
return True
def vocala(litera): # functia de verificare daca e vocala (include si majuscule)
lista_vocale = "aeiouAEIOU"
if litera in lista_vocale:
return True
else:
return False
def nrvocale(propozitie): # functia de rezolvare
frecventa_litere = [] # ne creem un vector de frecventa pentru litere
for i in range(128): # pana la 128 se afla ultimul cod ascii pentru litere
frecventa_litere.append(0)
for litera in propozitie:
if vocala(litera): # daca e vocala crestem frecventa
if litera >= 'a':
frecventa_litere[ord(litera) - 32] += 1
# daca e vocala mica, crestem frecventa la exhivalentul ei in majuscule
# deoarece in problema nu se tine cont daca e litera mare sau mica si le numaram pe toate la majuscule
else:
frecventa_litere[ord(litera)] += 1
aparitii_max = max(frecventa_litere) # gasim numarul cel mai mare de aparitii de vocale
for i in range(len(frecventa_litere)): # parcurgem iar vectorul de frecventa
if frecventa_litere[i] == aparitii_max: # daca am gasit vocala cu nr maxim de aparitii o afisam
print(chr(i))
return # si incheiem programul
if __name__ == '__main__':
# din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam
try:
sir = input(f"Introduceti textul ") # citirea textului
validare(sir) # apelul functiei de validare
nrvocale(sir) # apelul functiei de rezolvare
except ValueError:
print("Datele de intrare nu corespund restrictiilor impuse")
except IndexError:
print("Datele de intrare nu corespund restrictiilor impuse")