2346 - Paritate Siruri: Diferență între versiuni
(Pagină nouă: == Cerința == Se dau mai multe șiruri de caractere. Pentru fiecare șir, afișați șirul format doar din caracterele aflate pe poziții impare și șirul format din caracterele aflate pe poziții pare. Cele două șiruri vor fi separate printr-un singur spațiu, pe câte o linie. == Date de intrare == Fișierul de intrare paritatesiruriin.txt conține pe prima linie numărul K, reprezentând numărul de șiruri ce urmează a fi prelucrate. Pe următoarele K linii se află...) |
Fără descriere a modificării |
||
(Nu s-a afișat o versiune intermediară efectuată de același utilizator) | |||
Linia 28: | Linia 28: | ||
<br> | <br> | ||
== Rezolvare == | == Rezolvare == | ||
<syntaxhighlight lang="python" line> | <syntaxhighlight lang="python" line="1"> | ||
# 2346 Paritate Siruri | |||
def validare(nr_prop, propozitii): # functia de validare a datelor de intrare | |||
if nr_prop <= 0 or nr_prop >= 100: | |||
raise ValueError | |||
# daca datele de intrare nu corespund, ridicam eroarea ValueError | |||
if len(propozitii) != nr_prop: | |||
raise ValueError | |||
for prop in propozitii: | |||
if len(prop) > 10000: | |||
raise ValueError | |||
for litera in prop: | |||
if (litera < 'a' or litera > 'z') and (litera < 'A' or litera > 'Z'): # trebuie sa fie doar litera | |||
raise ValueError | |||
file_out.write("Datele de intrare corespund restrictiilor impuse\n") | |||
def paritate_siruri(siruri): # functia de rezolvare | |||
for sir in siruri: | |||
file_out.write(sir[1::2] + " " + sir[::2] + "\n") # din 2 in 2 afisat, intai de la pozitia 1 apoi de la 0 | |||
if __name__ == '__main__': | |||
file_in = open("paritatesiruriin.txt", "r") # declararea fisierelor | |||
file_out = open("paritatesiruriout.txt", "w") | |||
# din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam | |||
try: | |||
nr_siruri = int(file_in.readline()) # citirea numarului de siruri | |||
lista_siruri = [] | |||
for i in range(nr_siruri): | |||
propozitie = file_in.readline().strip() | |||
# citim fiecare propozitie si prin .strip() scapam de spatii sau \n de la final | |||
lista_siruri.append(propozitie) # adaugam textul intr-o lista de siruri de caractere | |||
validare(nr_siruri, lista_siruri) # apelul functiei de validare | |||
paritate_siruri(lista_siruri) # 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> |
Versiunea curentă din 4 mai 2023 13:04
Cerința
Se dau mai multe șiruri de caractere. Pentru fiecare șir, afișați șirul format doar din caracterele aflate pe poziții impare și șirul format din caracterele aflate pe poziții pare. Cele două șiruri vor fi separate printr-un singur spațiu, pe câte o linie.
Date de intrare
Fișierul de intrare paritatesiruriin.txt conține pe prima linie numărul K, reprezentând numărul de șiruri ce urmează a fi prelucrate. Pe următoarele K linii se află câte un șir format doar din litere mari și mici ale alfabetului limbii engleze.
Date de ieșire
Dacă datele sunt introduse corect, fișierul de ieșire paritatesiruriout.txt va conține: " Datele de intrare corespund restrictiilor impuse", apoi pe un rand nou va conține k linii: pe linia j se vor afla cele două șiruri separate printr-un singur spațiu care au rezultat din al j-lea șir citit. În caz contrar, se va afișa mesajul:" Datele de intrare nu corespund restrictiilor impuse" == Restricții și precizări ==1 ≤ K ≤ 100
- șirurile care se prelucrează au cel mult 10000 caractere
- numerotarea caracterelor din șir începe de la 0
Exemplu 1
- paritatesiruriin.txt
- 2
- PbInfo
- Informatica
- paritatesiruriout.txt
- Datele introduse corespund restricțiilor impuse.
- bno PIf
- nomtc Ifraia
Exemplu 2
- paritatesiruriin.txt
- (*&^%$%^&*()_
- paritatesiruriout.txt
- Datele de intrare nu corespund restricțiilor impuse.
Explicație
- Pentru primul șir PbInfo, S[0]='P', S[1]='b', S[2]='I', S[3]='n', S[4]='f', S[5]='o'. Caracterele aflate pe poziții impare for forma șirul bno, iar cele aflate pe poziții pare vor forma șirul PIf. Șirurile sunt separate printr-un singur spațiu.
Rezolvare
# 2346 Paritate Siruri
def validare(nr_prop, propozitii): # functia de validare a datelor de intrare
if nr_prop <= 0 or nr_prop >= 100:
raise ValueError
# daca datele de intrare nu corespund, ridicam eroarea ValueError
if len(propozitii) != nr_prop:
raise ValueError
for prop in propozitii:
if len(prop) > 10000:
raise ValueError
for litera in prop:
if (litera < 'a' or litera > 'z') and (litera < 'A' or litera > 'Z'): # trebuie sa fie doar litera
raise ValueError
file_out.write("Datele de intrare corespund restrictiilor impuse\n")
def paritate_siruri(siruri): # functia de rezolvare
for sir in siruri:
file_out.write(sir[1::2] + " " + sir[::2] + "\n") # din 2 in 2 afisat, intai de la pozitia 1 apoi de la 0
if __name__ == '__main__':
file_in = open("paritatesiruriin.txt", "r") # declararea fisierelor
file_out = open("paritatesiruriout.txt", "w")
# din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam
try:
nr_siruri = int(file_in.readline()) # citirea numarului de siruri
lista_siruri = []
for i in range(nr_siruri):
propozitie = file_in.readline().strip()
# citim fiecare propozitie si prin .strip() scapam de spatii sau \n de la final
lista_siruri.append(propozitie) # adaugam textul intr-o lista de siruri de caractere
validare(nr_siruri, lista_siruri) # apelul functiei de validare
paritate_siruri(lista_siruri) # 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")