0836 - AfisareVectorRec1: Difference between revisions
Catalin Moje (talk | contribs) No edit summary |
Catalin Moje (talk | contribs) No edit summary |
||
Line 6: | Line 6: | ||
==Date de ieșire== | ==Date de ieșire== | ||
Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței". | |||
==Restricţii şi precizări== | ==Restricţii şi precizări== | ||
Line 15: | Line 14: | ||
==Exemplu== | ==Exemplu== | ||
===Exemplu 1=== | |||
<syntaxhighlight lang="python" line> | |||
Introduceti valorile separate prin spatiu: 4 9 2 0 | |||
Datele de intrare corespund restrictiilor. | |||
Lista inversata este: 0 2 9 4 | |||
</syntaxhighlight> | |||
===Exemplu 2=== | |||
<syntaxhighlight lang="python" line> | |||
Introduceti valorile separate prin spatiu: a b c d | |||
Datele de intrare nu corespund cerintei. | |||
</syntaxhighlight> | |||
==Important== | ==Important== | ||
Line 21: | Line 30: | ||
==Rezolvare== | ==Rezolvare== | ||
<syntaxhighlight lang="python" line> | |||
def citire(): | |||
"""Functia citeste sirul de valori de la tastatura si il transforma in lista de intregi.""" | |||
sir = input("Introduceti valorile separate prin spatiu: ") | |||
lista = sir.split() # impartim sirul in cuvinte separate (presupunand ca sunt separate prin spatii) | |||
try: | |||
lista = [int(valoare) for valoare in lista] # transformam fiecare cuvant in intreg si cream o lista din acestea | |||
except ValueError: | |||
print("Datele de intrare nu corespund cerintei.") | |||
lista = [] # daca apar erori la transformarea cuvintelor in intregi, lista va fi goala | |||
return lista | |||
def | |||
def afis(lista): | |||
"""Functia afiseaza lista de valori in ordine inversa.""" | |||
if not lista: | |||
print("Nu s-au introdus valori.") | |||
return | return | ||
print("Lista inversata este:", end=" ") | |||
for i in range(len(lista) - 1, -1, -1): # parcurgem lista in ordine inversa | |||
print( | print(lista[i], end=" ") | ||
def main(): | print() # afisam un rand nou la final | ||
print(" | |||
def main(): | |||
lista = citire() | |||
if lista: | |||
print("Datele de intrare corespund restrictiilor.") | |||
afis(lista) | |||
if __name__ == '__main__': | |||
main() | |||
</syntaxhighlight> | |||
==Explicații== | |||
Programul citeste un sir de valori naturale de la tastatura si apoi afiseaza aceste valori in ordine inversa, utilizand o functie recursiva. | |||
In functia citire() se citeste de la tastatura cate o valoare la fiecare iteratie, verificandu-se daca aceasta este diferita de 0 si daca este un numar natural. Valoarea citita se adauga la lista lista_valori pana cand se citeste 0, caz in care se returneaza lista cu valorile citite. | |||
In functia afisare_inversa() se apeleaza functia citire() pentru a citi lista de valori si apoi se apeleaza functia recursiva afisare_inversa_recursiv() cu parametrii lista de valori si indexul ultimului element din lista. Aceasta functie recursiva se apeleaza pe ea insasi, afisandu-se valoarea corespunzatoare indexului curent si apoi apelandu-se recursiv functia cu indexul anterior, pana cand indexul devine 0 si se afiseaza ultima valoare din lista. | |||
In functia main() se apeleaza functia afisare_inversa() pentru a citi si afisa valorile in ordine inversa, tratandu-se cazurile in care valorile citite nu corespund cerintelor prin afisarea unui mesaj corespunzator. |
Revision as of 20:18, 3 April 2023
Cerinţa
Să se scrie o funcție recursivă care citește de la tastatură un șir de valori naturale și le afișează în ordine inversă, cu câte un spațiu între ele.
Date de intrare
Se va introduce de la tastatură un șir de valori naturale care vor fi transmise ca perimetrii
Date de ieșire
Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței".
Restricţii şi precizări
numele funcției va fi afis; funcția nu va avea parametri și nu va returna nimic; șirul de valori citite se încheie la citirea valorii 0.
Exemplu
Exemplu 1
<syntaxhighlight lang="python" line> Introduceti valorile separate prin spatiu: 4 9 2 0 Datele de intrare corespund restrictiilor. Lista inversata este: 0 2 9 4 </syntaxhighlight>
Exemplu 2
<syntaxhighlight lang="python" line> Introduceti valorile separate prin spatiu: a b c d Datele de intrare nu corespund cerintei. </syntaxhighlight>
Important
Soluţia propusă va conţine doar definiţia funcţiei cerute. Prezenţa în soluţie a altor instrucţiuni poate duce erori de compilare sau de execuţie care vor avea ca efect depunctarea soluţiei.
Rezolvare
<syntaxhighlight lang="python" line> def citire():
"""Functia citeste sirul de valori de la tastatura si il transforma in lista de intregi.""" sir = input("Introduceti valorile separate prin spatiu: ") lista = sir.split() # impartim sirul in cuvinte separate (presupunand ca sunt separate prin spatii) try: lista = [int(valoare) for valoare in lista] # transformam fiecare cuvant in intreg si cream o lista din acestea except ValueError: print("Datele de intrare nu corespund cerintei.") lista = [] # daca apar erori la transformarea cuvintelor in intregi, lista va fi goala return lista
def afis(lista):
"""Functia afiseaza lista de valori in ordine inversa.""" if not lista: print("Nu s-au introdus valori.") return print("Lista inversata este:", end=" ") for i in range(len(lista) - 1, -1, -1): # parcurgem lista in ordine inversa print(lista[i], end=" ") print() # afisam un rand nou la final
def main():
lista = citire() if lista: print("Datele de intrare corespund restrictiilor.") afis(lista)
if __name__ == '__main__':
main()
</syntaxhighlight>
Explicații
Programul citeste un sir de valori naturale de la tastatura si apoi afiseaza aceste valori in ordine inversa, utilizand o functie recursiva.
In functia citire() se citeste de la tastatura cate o valoare la fiecare iteratie, verificandu-se daca aceasta este diferita de 0 si daca este un numar natural. Valoarea citita se adauga la lista lista_valori pana cand se citeste 0, caz in care se returneaza lista cu valorile citite.
In functia afisare_inversa() se apeleaza functia citire() pentru a citi lista de valori si apoi se apeleaza functia recursiva afisare_inversa_recursiv() cu parametrii lista de valori si indexul ultimului element din lista. Aceasta functie recursiva se apeleaza pe ea insasi, afisandu-se valoarea corespunzatoare indexului curent si apoi apelandu-se recursiv functia cu indexul anterior, pana cand indexul devine 0 si se afiseaza ultima valoare din lista.
In functia main() se apeleaza functia afisare_inversa() pentru a citi si afisa valorile in ordine inversa, tratandu-se cazurile in care valorile citite nu corespund cerintelor prin afisarea unui mesaj corespunzator.