4104 - afisare21: Difference between revisions

From Bitnami MediaWiki
No edit summary
 
(3 intermediate revisions by the same user not shown)
Line 25: Line 25:
===Exemplul 2===
===Exemplul 2===
; Intrare
; Intrare
: 7
:-2
: 1 2 3 4
: 1 2 3
: -4
: 1 2 3
; Ieșire
; Ieșire
: Datele nu corespund restricțiilor impuse.
: Datele nu corespund restricțiilor impuse.
<br>
<br>
== Rezolvare ==  
== Rezolvare ==  
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
Line 51: Line 54:




def citire_conform_restrictiilor():
def citire_conform_restrictiilor(n, x, m, y):
    n = int(input())
    x = list(map(int, input().split()))
     if n != len(x):
     if n != len(x):
         print("Datele nu corespund restricțiilor impuse.")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
    m = int(input())
    y = list(map(int, input().split()))
     if m != len(y):
     if m != len(y):
         print("Datele nu corespund restricțiilor impuse.1")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
     for element in x:
     for element in x:
         if element < -1000000000 or element > 1000000000:
         if element < -1000000000 or element > 1000000000:
             print("Datele nu corespund restricțiilor impuse.3")
             print("Datele nu corespund restricțiilor impuse.")
             exit()
             exit()
     for element in y:
     for element in y:
         if element < -1000000000 or element > 1000000000:
         if element < -1000000000 or element > 1000000000:
             print("Datele nu corespund restricțiilor impuse.4")
             print("Datele nu corespund restricțiilor impuse.")
             exit()
             exit()
     if n < 1 or n > 10000:
     if n < 1 or n > 10000:
         print("Datele nu corespund restricțiilor impuse.1")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
     if m < 1 or m > 10000:
     if m < 1 or m > 10000:
         print("Datele nu corespund restricțiilor impuse.1")
         print("Datele nu corespund restricțiilor impuse.")
         exit()
         exit()
     print("Datele sunt introduse corect.")
     print("Datele sunt introduse corect.")
    return n, x, m, y




if __name__ == '__main__':
if __name__ == '__main__':
     n, x, m, y = citire_conform_restrictiilor()
     n = int(input())
    x = list(map(int, input().split()))
    m = int(input())
    y = list(map(int, input().split()))
    citire_conform_restrictiilor(n, x, m, y)
     afis_el_din_vect_x_mai_mici_decat_toate_el_din_y(n, x, m, y)
     afis_el_din_vect_x_mai_mici_decat_toate_el_din_y(n, x, m, y)




Line 99: Line 102:
</syntaxhighlight>
</syntaxhighlight>
== Explicație rezolvare==
== Explicație rezolvare==
   Acest program primește două liste de numere întregi x și y și determină toate elementele din lista x care sunt mai mici decât toate elementele din lista y. Pentru a face asta, programul găsește cel mai mic element din lista y, apoi compară fiecare element din lista x cu acest minim și afișează elementele care sunt mai mici. Dacă nu există astfel de elemente, programul afișează "NU EXISTA". <br>  Funcția '''citire_conform_restrictiilor()''' primește datele de intrare conform unor restricții impuse și verifică dacă acestea sunt respectate. Aceasta primește doi vectori x și y și lungimile lor corespunzătoare n și m. Se verifică dacă lungimile corespund cu valorile n și m date ca intrare. De asemenea, se verifică dacă elementele din ambele liste sunt în intervalul [-1000000000, 1000000000]. Dacă datele de intrare nu respectă restricțiile impuse, programul va afișa un mesaj corespunzător și se va opri.<br>  Funcția '''afis_el_din_vect_x_mai_mici_decat_toate_el_din_y()''' primește cele două liste și apelează algoritmul descris mai sus pentru a găsi elementele din lista x mai mici decât toate elementele din lista y. Dacă nu există astfel de elemente, afișează mesajul "NU EXISTA".
   Acest cod conține două funcții: afis_el_din_vect_x_mai_mici_decat_toate_el_din_y și citire_conform_restrictiilor(), care vor fi apelate în interiorul secțiunii '''if __name__ == '__main__':''' (linia 44) după citirea numărului n, vectorului x, m și vectorului y (se folosește comanda input() pentru citire și int() pentru a converti în numere).<br>  Funcția '''citire_conform_restrictiilor''' primește ca parametrii numărul n, vectorul x, numărul m, respectiv vectorul y, și verifică dacă datele introduse respectă restricțiile (n, m să fie lungimile vectorilor x, respectiv y, elementele celor doi vectori să fie cuprinse între -1000000000 și 1000000000, n și m să fie cuprinse între 1 și 10000). Dacă datele nu corespund restricțiilor impuse, afișează "Datele nu corespund restricțiilor impuse." și se oprește execuția programului prin apelarea funcției exit(), iar dacă ele respectă restricțiile se afișează "Datele sunt introduse corect." și se poate continua programul.<br>  Funcția '''afis_el_din_vect_x_mai_mici_decat_toate_el_din_y''' primește patru parametri:<br>-> n: numărul de elemente din vectorul x<br>-> x: vectorul x<br>-> m: numărul de elemente din vectorul y<br>-> y: vectorul y<br>  Funcția '''afis_el_din_vect_x_mai_mici_decat_toate_el_din_y(n, x, m, y)''' are următorul comportament:<br>-> Inițializează variabila minim cu o valoare mare și variabila exista cu valoarea False.<br>-> Parcurge vectorul y și găsește valoarea minimă din acesta. Valoarea minimă o stochează în variabila minim.<br>-> Parcurge vectorul x și afișează elementele din acesta care sunt mai mici decât minim. Dacă există cel puțin un astfel de element, variabila exista devine True.<br>-> Dacă nu există niciun element din vectorul x mai mic decât toate elementele din vectorul y, se afișează mesajul "NU EXISTA".

Latest revision as of 11:11, 26 April 2023

Sursa: - afisare21


Cerinţa[edit | edit source]

Se dă un vector x cu n elemente numere întregi, și un vector y cu m elemente, de asemenea numere întregi. Să se afișeze toate elementele din vectorul x care sunt mai mici decât toate elementele din vectorul y.

Date de intrare[edit | edit source]

Programul citește de la tastatură numărul n, iar apoi cele n elemente ale vectorului x. Apoi și citește m și cele m elemente ale lui y.

Date de ieșire[edit | edit source]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou va afișa elementele din vectorul x care sunt mai mici decât toate elementele din vectorul y, sau NU EXISTA dacă vectorul x nu conține astfel de elemente. Î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 | edit source]

  • 1n, m10.000
  • elementele celor 2 vectori vor fi din intervalul [-1.000.000.000,1.000.000.000]

Exemple[edit | edit source]

Exemplul 1[edit | edit source]

Intrare
7
9 -6 5 14 2 1 10
8
8 14 9 14 16 15 4 6
Ieșire
Datele sunt introduse corect.
-6 2 1

Exemplul 2[edit | edit source]

Intrare
-2
1 2 3
-4
1 2 3
Ieșire
Datele nu corespund restricțiilor impuse.


Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 4104

def afis_el_din_vect_x_mai_mici_decat_toate_el_din_y(n, x, m, y):

   minim = 1000000001
   exista = False
   for i in range(m):
       if y[i] < minim:
           minim = y[i]
   for i in range(n):
       advevarat = True
       if x[i] > minim:
           advevarat = False
       if advevarat:
           exista = True
           print(x[i], end=" ")
   if not exista:
       print("NU EXISTA")


def citire_conform_restrictiilor(n, x, m, y):

   if n != len(x):
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   if m != len(y):
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   for element in x:
       if element < -1000000000 or element > 1000000000:
           print("Datele nu corespund restricțiilor impuse.")
           exit()
   for element in y:
       if element < -1000000000 or element > 1000000000:
           print("Datele nu corespund restricțiilor impuse.")
           exit()
   if n < 1 or n > 10000:
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   if m < 1 or m > 10000:
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   print("Datele sunt introduse corect.")


if __name__ == '__main__':

   n = int(input())
   x = list(map(int, input().split()))
   m = int(input())
   y = list(map(int, input().split()))
   citire_conform_restrictiilor(n, x, m, y)
   afis_el_din_vect_x_mai_mici_decat_toate_el_din_y(n, x, m, y)








</syntaxhighlight>

Explicație rezolvare[edit | edit source]

  Acest cod conține două funcții: afis_el_din_vect_x_mai_mici_decat_toate_el_din_y și citire_conform_restrictiilor(), care vor fi apelate în interiorul secțiunii if __name__ == '__main__': (linia 44) după citirea numărului n, vectorului x, m și vectorului y (se folosește comanda input() pentru citire și int() pentru a converti în numere).
Funcția citire_conform_restrictiilor primește ca parametrii numărul n, vectorul x, numărul m, respectiv vectorul y, și verifică dacă datele introduse respectă restricțiile (n, m să fie lungimile vectorilor x, respectiv y, elementele celor doi vectori să fie cuprinse între -1000000000 și 1000000000, n și m să fie cuprinse între 1 și 10000). Dacă datele nu corespund restricțiilor impuse, afișează "Datele nu corespund restricțiilor impuse." și se oprește execuția programului prin apelarea funcției exit(), iar dacă ele respectă restricțiile se afișează "Datele sunt introduse corect." și se poate continua programul.
Funcția afis_el_din_vect_x_mai_mici_decat_toate_el_din_y primește patru parametri:
-> n: numărul de elemente din vectorul x
-> x: vectorul x
-> m: numărul de elemente din vectorul y
-> y: vectorul y
Funcția afis_el_din_vect_x_mai_mici_decat_toate_el_din_y(n, x, m, y) are următorul comportament:
-> Inițializează variabila minim cu o valoare mare și variabila exista cu valoarea False.
-> Parcurge vectorul y și găsește valoarea minimă din acesta. Valoarea minimă o stochează în variabila minim.
-> Parcurge vectorul x și afișează elementele din acesta care sunt mai mici decât minim. Dacă există cel puțin un astfel de element, variabila exista devine True.
-> Dacă nu există niciun element din vectorul x mai mic decât toate elementele din vectorul y, se afișează mesajul "NU EXISTA".