2441 - Pereche descentrata
De la Universitas MediaWiki
Cerinţa
O pereche de cuvinte, unul cu număr par de litere, iar celălalt cu număr impar de litere, se numește descentrată dacă se poate obține cuvântul cu număr par de litere din celălalt, prin duplicarea caracterului din mijlocul acestuia.
Exemplu: perechile crezi și creezi, respectiv a și aa sunt descentrate.
Date de intrare
Programul citește de la tastatură un text.
Date de ieşire
Programul va afișa pe ecran mesajul DA, dacă acesta conține cel puțin o pereche descentrată, sau mesajul NU în caz contrar.
Restricții și precizări
- textul are cel mult 100 de caractere
- cuvintele sunt formate din litere mici ale alfabetului englez
- cuvintele sunt separate prin câte un spațiu
Exemplul 1
- Intrare
crezi ca poti sa creezi ceva original
- Ieșire
Datele introduse corespund restricțiilor impuse. DA
Explicație
Perechea descentrată de cuvinte este crezi – creezi.
Exemplul 2
- Intrare
242434545
- Ieșire
Datele introduse nu corespund restricțiilor impuse.
Rezolvare
# Definim funcția de verificare a valorilor s
def verificare(s_val):
# Verificăm dacă s respectă restricțiile problemei
if 1 <= len(s_val) <= 100 and all(c.islower() or c.isspace() for c in s_val):
# Dacă valorile sunt valide, returnăm True
return True
else:
# Dacă valorile nu sunt valide, ridicăm o excepție
raise ValueError
# Definim funcția pentru verificarea dacă există cel puțin o pereche descentrată
def exista_pereche_descentrata(s_cuv):
# Transformăm șirul în listă de cuvinte
cuvinte = s_cuv.split()
# Pentru fiecare cuvânt cu număr impar de litere
for cuvant in cuvinte:
if len(cuvant) % 2 == 1:
# Calculăm cuvântul descentrat
mijloc = len(cuvant) // 2
cuvant_descentrat = cuvant[:mijloc] + cuvant[mijloc] * 2 + cuvant[mijloc+1:]
# Verificăm dacă cuvântul descentrat se află în listă
if cuvant_descentrat in cuvinte:
return 'DA'
return 'NU'
# Verificăm dacă acest script este rulat direct (nu este importat ca modul)
if __name__ == '__main__':
try:
# Citim șirul de caractere
s = input("Introduceti sirul de caractere: ")
# Verificăm dacă datele introduse sunt valide
if verificare(s):
# Dacă datele sunt valide, afișăm un mesaj de confirmare
print("Datele introduse corespund restricțiilor impuse.")
# Verificăm dacă există cel puțin o pereche descentrată și afișăm rezultatul
print(exista_pereche_descentrata(s))
# Tratăm cazul în care datele introduse nu sunt valide
except ValueError:
# Afișăm un mesaj de eroare
print("Datele introduse nu corespund restricțiilor impuse.")