4104 - afisare21: Difference between revisions
Pagină nouă: Sursa: [https://www.pbinfo.ro/probleme/2919/2groups 2919 - 2Groups] ---- == Cerinţa == 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 == Programul citește de la tastatură numărul '''n''', iar apoi cele '''n''' elemente ale vectorului '''x'''. Apoi și... |
|||
(5 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
Sursa: [https://www.pbinfo.ro/probleme/ | Sursa: [https://www.pbinfo.ro/probleme/4104/afisare21 - afisare21] | ||
---- | ---- | ||
== Cerinţa == | == Cerinţa == | ||
Line 25: | Line 25: | ||
===Exemplul 2=== | ===Exemplul 2=== | ||
; Intrare | ; Intrare | ||
: | :-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 41: | Line 44: | ||
minim = y[i] | minim = y[i] | ||
for i in range(n): | for i in range(n): | ||
advevarat = True | |||
if x[i] > minim: | if x[i] > minim: | ||
advevarat = False | |||
if | if advevarat: | ||
exista = True | exista = True | ||
print(x[i], end=" ") | print(x[i], end=" ") | ||
Line 51: | Line 54: | ||
def citire_conform_restrictiilor( | def citire_conform_restrictiilor(n, x, m, y): | ||
if n != len(x): | if n != len(x): | ||
print("Datele nu corespund restricțiilor impuse.") | print("Datele nu corespund restricțiilor impuse.") | ||
exit() | exit() | ||
if m != len(y): | if m != len(y): | ||
print("Datele nu corespund restricțiilor impuse. | 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. | 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. | 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. | 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. | print("Datele nu corespund restricțiilor impuse.") | ||
exit() | exit() | ||
print("Datele sunt introduse corect.") | print("Datele sunt introduse corect.") | ||
if __name__ == '__main__': | if __name__ == '__main__': | ||
n | 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 | 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]
- 1 ⩽ n, m ⩽ 10.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>
- 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".