0488 - Afisare: Difference between revisions

From Bitnami MediaWiki
Pagină nouă: Sursa: [https://www.pbinfo.ro/probleme/488/afisare - 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 su...
 
mNo edit summary
 
(4 intermediate revisions by the same user not shown)
Line 32: Line 32:
===Exemplul 3===
===Exemplul 3===
; Intrare
; Intrare
: 1234
: 2
: 1234 1
; Ieșire
; Ieșire
: Datele nu corespund restricțiilor impuse.
: Datele nu corespund restricțiilor impuse.
Line 40: Line 41:
# 0488 - Afisare
# 0488 - Afisare


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


    if n % 2 == 0:
        n -= 1


def citire_conform_restrictiilor():
    for i in range(n-1, -1, -2):
    n = int(input())
        print(vector[i], end=' ')
 
 
def citire_conform_restrictiilor(vector, n):
     if n < 1 or n > 1000:
     if n < 1 or n > 1000:
         print("Datele nu corespund restricțiilor impuse.")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
     vector = list(map(int, input().split()))
     if n != len(vector):
        print("Datele nu corespund restricțiilor impuse.")
        exit()
     for x in vector:
     for x in vector:
         if x >= 1000000:
         if x >= 1000000:
             print("Datele nu corespund restricțiilor impuse.")
             print("Datele nu corespund restricțiilor impuse.")
             exit()
             exit()
    if vector[n - 1] == 0:
        print("Datele nu corespund restricțiilor impuse.")
        exit()
     print("Datele sunt introduse corect.")
     print("Datele sunt introduse corect.")
    return vector, n




if __name__ == '__main__':
if __name__ == '__main__':
     vector, n = citire_conform_restrictiilor()
    n = int(input())
     afisare_elemente_multiple_cu_ultimul_element(vector, n)
     vector = list(map(int, input().split()))
    citire_conform_restrictiilor(vector, n)
     elem_indice_par_elem_indice_impar_descr(vector, n)
 




Line 72: Line 79:


</syntaxhighlight>
</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).<br>  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.<br>  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)).

Latest revision as of 19:21, 8 April 2023

Sursa: - Afisare


Cerinţa[edit]

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[edit]

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

Date de ieșire[edit]

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[edit]

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

Exemple[edit]

Exemplul 1[edit]

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

Exemplul 2[edit]

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

Exemplul 3[edit]

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


Rezolvare[edit]

<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[edit]

   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)).