0488 - Afisare

From Bitnami MediaWiki
Revision as of 19:21, 8 April 2023 by Csatari Mălina (talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Sursa: - Afisare


Cerinţa

Se citește un vector cu n elemente, numere naturale. Să se afișeze elementele cu indici pari în ordinea crescătoare a indicilor, iar elementele cu indici impari în ordinea descrescătoare a indicilor.

Date de intrare

Programul citește de la tastatură numărul n, iar apoi n numere naturale, reprezentând elementele vectorului.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", iar pe un rând nou afișează pe o linie elementele cu indici pari, în ordinea crescătoare a indicilor, separate prin exact un spațiu, apoi pe linia următoare elementele cu indici impari, în ordinea descrescătoare a indicilor, separate prin exact un spațiu. În cazul în care datele nu respectă restricțiile, se va afișa pe ecran: "Datele nu corespund restricțiilor impuse.".

Restricţii şi precizări

  • 1 ⩽ n ⩽ 1.000
  • elementele vectorului vor fi mai mici decât 1.000
  • numerotarea indicilor va începe de la 1

Exemple

Exemplul 1

Intrare
5
7 9 2 6 8
Ieșire
Datele sunt introduse corect.
9 6
8 2 7

Exemplul 2

Intrare
4
1 2 3 4
Ieșire
Datele sunt introduse corect.
2 4
3 1

Exemplul 3

Intrare
2
1234 1
Ieșire
Datele nu corespund restricțiilor impuse.


Rezolvare

<syntaxhighlight lang="python" line>

  1. 0488 - Afisare

def elem_indice_par_elem_indice_impar_descr(vector, n):

   for i in range(1, n, 2):
       print(vector[i], end=' ')
   print()
   if n % 2 == 0:
       n -= 1
   for i in range(n-1, -1, -2):
       print(vector[i], end=' ')


def citire_conform_restrictiilor(vector, n):

   if n < 1 or n > 1000:
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   if n != len(vector):
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   for x in vector:
       if x >= 1000000:
           print("Datele nu corespund restricțiilor impuse.")
           exit()
   print("Datele sunt introduse corect.")


if __name__ == '__main__':

   n = int(input())
   vector = list(map(int, input().split()))
   citire_conform_restrictiilor(vector, n)
   elem_indice_par_elem_indice_impar_descr(vector, n)




</syntaxhighlight>

Explicație rezolvare

   Programul de mai sus conține două funcții, funcția elem_indice_par_elem_indice_impar_descr(vector, n) și funcția citire_conform_restrictiilor(vector, n), care se vor rula în interiorul main-ului (if __name__ == '__main__' , linia 29) după citirea numărului n (linia 30) și celor n numere pe care le vom pune în șirul vector (linia 31).
După ce am citit elementele, se va apela funcția citire_conform_restrictiilor(vector, n) care primește doi parametri: vectorul „vector” și lungimea sa, reprezentată de variabila „n”. Funcția verifică mai întâi dacă lungimea vectorului n este între 1 și 1000 (linia 16), dacă n este lungimea vectorului (linia 19) și dacă elementele vectorului sunt mai mici decât 1000 (liniile 22, 23). Dacă oricare dintre condiții este încălcată, se va afișa mesajul „Datele nu corespund restricțiilor impuse.” și se va ieși din program cu comanda exit(). Dacă toate condițiile sunt respectate, se va afișa mesajul „Datele sunt introduse corect.” (linia 26) și se va continua programul.
Dacă s-au introdus corect datele, se va apela funcția elem_indice_par_elem_indice_impar_descr(vector, n), care primește ca parametru vectorul vector și dimensiunea acestuia n. Această funcție afișează elementele de pe pozițiile pare și impare din vector, în ordine. În primul rând, sunt afișate elementele de pe pozițiile pare, utilizând un for loop care trece prin elementele de la 1 la n cu pași de 2 (deoarece vectorul începe de pe poziția 0, așadar pozițiile pare vor fi cele impare). După aceea, dacă dimensiunea vectorului este pară, aceasta este decrementată cu 1 (pentru a afișa toate valorile impare). În cele din urmă, sunt afișate elementele de pe pozițiile impare, începând de la ultimul element al vectorului și mergând înapoi cu pași de 2 până la primul element (prima valoare este n-1 deoarece vectorul nostru are indicii de la [0, n)).