4041 - Mulțime Gauss: Difference between revisions
Pagină nouă: == Cerința == Știind numarul '''nr''', să se afle '''multimea'''. == Date de intrare == Programul citește de la tastatură '''nr'''. == Date de ieșire == Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse". În următorul rând se va afișa pe ecran numărul '''multimea''', reprezentând numărul mulțimii din care face parte '''nr'''. În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va... |
No edit summary |
||
(One intermediate revision by the same user not shown) | |||
Line 1: | Line 1: | ||
== Cerința == | == Cerința == | ||
Fie șirul 1, 2, 3, 4, 5, 6, 7, ..., '''nr''', ... care îndeplinește regula de mai jos: | |||
1 face parte din mulțimea numerotată cu 1. | |||
2, 3 fac parte din mulțimea numerotată cu 2. | |||
4, 5, 6 fac parte din mulțimea numerotată cu 3. | |||
7, 8, 9, 10 fac parte din mulțimea numerotată cu 4 | |||
... | |||
Iar '''nr''' face parte din mulțimea numerotată cu '''multimea'''. | |||
Știind numarul '''nr''', să se afle '''multimea'''. | Știind numarul '''nr''', să se afle '''multimea'''. | ||
== Date de intrare == | == Date de intrare == | ||
Line 7: | Line 21: | ||
În următorul rând se va afișa pe ecran numărul '''multimea''', reprezentând numărul mulțimii din care face parte '''nr'''. | În următorul rând se va afișa pe ecran numărul '''multimea''', reprezentând numărul mulțimii din care face parte '''nr'''. | ||
În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul " | În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Nu au fost respectate cerintele impuse". | ||
== Restricții și precizări == | == Restricții și precizări == | ||
* 1 ⩽ '''nr''' ⩽ 2000000001 | * 1 ⩽ '''nr''' ⩽ 2000000001 | ||
Line 26: | Line 40: | ||
<syntaxhighlight lang="python" line> | <syntaxhighlight lang="python" line> | ||
# 4041 - Multime Gauss | # 4041 - Multime Gauss | ||
# Importam functia sqrt din modulul math | |||
from math import sqrt | from math import sqrt | ||
Line 37: | Line 52: | ||
def multime_gauss(nr): | def multime_gauss(nr): | ||
# https://web.archive.org/web/20230510032144if_/https://i.imgur.com/OXqZjTf.png | |||
delta = 1 + 8 * (nr - 1) | delta = 1 + 8 * (nr - 1) | ||
Line 45: | Line 61: | ||
if __name__ == '__main__': | if __name__ == '__main__': | ||
# Citim de la tastatura numerele cerute | |||
nr = int(input()) | nr = int(input()) | ||
# Verificam daca datele introduse sunt valide | |||
# daca nu afisam mesajul corespunsador | |||
try: | try: | ||
validare(nr) | validare(nr) |
Latest revision as of 11:09, 23 May 2023
Cerința[edit | edit source]
Fie șirul 1, 2, 3, 4, 5, 6, 7, ..., nr, ... care îndeplinește regula de mai jos:
1 face parte din mulțimea numerotată cu 1.
2, 3 fac parte din mulțimea numerotată cu 2.
4, 5, 6 fac parte din mulțimea numerotată cu 3.
7, 8, 9, 10 fac parte din mulțimea numerotată cu 4
...
Iar nr face parte din mulțimea numerotată cu multimea.
Știind numarul nr, să se afle multimea.
Date de intrare[edit | edit source]
Programul citește de la tastatură nr.
Date de ieșire[edit | edit source]
Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse". În următorul rând se va afișa pe ecran numărul multimea, reprezentând numărul mulțimii din care face parte nr.
În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Nu au fost respectate cerintele impuse".
Restricții și precizări[edit | edit source]
- 1 ⩽ nr ⩽ 2000000001
Exemplu 1[edit | edit source]
- Intrare
- 7
- Ieșire
- Datele de intrare corespund restricțiilor impuse
- 4
Exemplu 2[edit | edit source]
- Intrare
- 0
- Ieșire
- Nu au fost respectate cerintele impuse
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line>
- 4041 - Multime Gauss
- Importam functia sqrt din modulul math
from math import sqrt
def validare(nr):
# Daca datele sunt invalide v-om face raise la eroarea ValueError
if (not (nr >= 1 and nr <= 2000000001)): raise ValueError
def multime_gauss(nr):
# https://web.archive.org/web/20230510032144if_/https://i.imgur.com/OXqZjTf.png delta = 1 + 8 * (nr - 1)
multimea = int((1 + sqrt(delta)) // 2)
print(multimea)
if __name__ == '__main__':
# Citim de la tastatura numerele cerute nr = int(input())
# Verificam daca datele introduse sunt valide # daca nu afisam mesajul corespunsador try: validare(nr) except ValueError: print("Nu au fost respectate cerintele impuse") else: print("Datele de intrare corespund restricțiilor impuse")
multime_gauss(nr)
</syntaxhighlight>