3658 – NrTriplete
Sursa: NrTriplete
Cerinţă
Se dă un șir cu n
elemente întregi și s, un nr întreg. Funcția returnează numărul de triplete (sir[i], sir[j], sir[k])
, unde 0 ≤ i < j < k < n
și sir[i] + sir[j] + sir[k] < S
.
Date de intrare
Programul va citi de la tastatură valoarean
, apoi n
numere întregi reprezentând elementele șirului, apoi valoarea s.
Date de ieșire
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele introduse sunt corecte!", apoi se va afișa totalul de triplete care îndeplinesc condițiile date. În cazul în care datele nu respectă restricțiile, se va afișa mesajul "Datele introduse nu sunt corecte!".
Restricţii şi precizări
- 3 <= n <= 2000
- valorile elementelor șirului vor fi cuprinse între -100.000.000 și 100.000.000
- -100.000.000 <= s <= 100.000.000
Exemple
Exemplul 1
- Intrare
- Introduceti numarul de elemente a sirului: 4
- Introduceti 4 numere separate prin spatiu:1 -2 0 4
- Introduceti valoarea s: 5
- Ieșire
- Datele introduse sunt corecte!
- count: 3
Exemplul 2
- Intrare
- Introduceti numarul de elemente a sirului: 3
- Introduceti 3 numere separate prin spatiu: 1231 1 321 41
- Ieșire
- Datele introduse sunt incorecte!
Rezolvare
<syntaxhighlight lang="python" line="1"> def is_integer(value):
return value.isdigit()
def verificare_nr_elemente(n):
if is_integer(n): if 3 <= int(n) <= 2000: return n else: print("Datele introduse sunt incorecte!") exit() else: print("Datele introduse sunt incorecte!") exit()
def verificare_vector(n, vector):
if len(vector) != n: print("Datele introduse sunt incorecte!") exit() for i in vector: if -100000000 <= int(i) <= 100000000: continue else: print("Datele introduse sunt incorecte!") exit()
def verificare_s(s):
if is_integer(s): if 3 <= int(s) <= 2000: return s else: print("Datele introduse sunt incorecte!") exit() else: print("Datele introduse sunt incorecte!") exit()
def nr_triplete(sir, n, S):
count = 0 for i in range(n-2): for j in range(i+1, n-1): for k in range(j+1, n): if sir[i]+sir[j]+sir[k] < S: count += 1 print("count:",count)
if __name__ == '__main__':
n = input("Introduceti numarul de elemente a sirului: ") verificare_nr_elemente(n) lst_int = list(map(int, input(f"Introduceti {n} numere separate prin spatiu:").split())) verificare_vector(n, lst_int) s = input("Introduceti valoarea s: ") verificare_s(s) print("Datele introduse sunt corecte!") nr_triplete(lst_int, int(n), int(s))
</syntaxhighlight>
Explicație rezolvare
- Funcția
is_integer(value)
verifică dacăvalue
este un string reprezentând un număr întreg (adică conține doar cifre). ReturneazăTrue
dacă este șiFalse
în caz contrar. - Funcția
verificare_nr_elemente(n)
verifică dacăn
este un string reprezentând un număr întreg între 3 și 2000. În cazul în care este valid, returneazăn
, altfel afișează un mesaj de eroare și iese din program. - Funcția
verificare_vector(n, vector)
verifică dacă toate elementele dinvector
sunt numere întregi între -100000000 și 100000000. În cazul în care sunt valide, nu face nimic, altfel afișează un mesaj de eroare și iese din program. - Funcția
verificare_s(s)
verifică dacăs
este un string reprezentând un număr întreg între 3 și 2000. În cazul în care este valid, returneazăs
, altfel afișează un mesaj de eroare și iese din program. - Funcția
nr_triplete(sir, n, S)
primește un tablousir
den
numere întregi și un număr întregS
. Parcurge toate tripletele posibile din tablou și numără cele pentru care suma este strict mai mică decâtS
. Afișează rezultatul final. - În funcția
main
, se citesc numărul de elemente, vectorul și valoareaS
cu ajutorul unor input-uri și se validează folosind funcțiile de mai sus. Apoi, se apelează funcțianr_triplete
cu argumentele corespunzătoare. - Comanda
list(map(int, input(f"Introduceti {n} numere separate prin spatiu:").split()))
transformă string-ul citit de la tastatură într-o listă de numere întregi. Mai întâi se citesc valorile cuinput(f"Introduceti {n} numere separate prin spatiu:")
, apoi se separă folosind funcțiasplit()
și se transformă fiecare element din listă într-un număr întreg folosind funcțiaint
.