2915 - Sum Square: Difference between revisions
Paul Ungur (talk | contribs) Pagină nouă: ==Cerința== Se dă numărul natural <span style=“color: red”>n</span>. Determinați dacă numărul se poate scrie ca sumă de două pătrate perfecte. Dacă da, afișați două pătrate perfecte a căror sumă este <span style=“color: red”>n</span>, în ordine crescătoare, sau mesajul <span style=“color: red”>NU</span> în caz contrar. ==Date de intrare== Programul citește de la tastatură numărul <span style=“color: red”>n</span>; ==Date de ieșire== Pr... |
Paul Ungur (talk | contribs) No edit summary |
||
Line 23: | Line 23: | ||
import math | import math | ||
def | |||
def validare_date(n): | |||
"""Functie de validare""" | """Functie de validare""" | ||
if not 1 <= n <= 10**15: | if not 1 <= n <= 10**15: | ||
Line 30: | Line 31: | ||
return True | return True | ||
def | def sum_square(n): | ||
n = | ok = False | ||
for i in range(1, int(math.sqrt(n // 2)) + 1): | |||
x = i * i | |||
y = n - x | |||
j = int(math.sqrt(y)) | |||
if j * j == y and not ok: | |||
print(min(y, x), max(x, y)) | |||
ok = True | |||
print( | |||
if not ok: | |||
print("NU") | |||
if __name__ == '__main__': | if __name__ == '__main__': | ||
n = int(input()) | |||
if validare_date(n): | |||
print("Date de intrare valide") | |||
sum_square(n) | |||
else: | |||
print("Date de intrare invalide") | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Revision as of 16:08, 26 April 2023
Cerința
Se dă numărul natural n. Determinați dacă numărul se poate scrie ca sumă de două pătrate perfecte. Dacă da, afișați două pătrate perfecte a căror sumă este n, în ordine crescătoare, sau mesajul NU în caz contrar.
Date de intrare
Programul citește de la tastatură numărul n;
Date de ieșire
Programul va afișa pe ecran cele 2 pătrate care alcătuiesc numărul sau mesajul NU în cazul în care nu există.
Restricții și precizări
1≤n≤1015 dacă există mai multe perechi de pătrate perfecte a căror sumă este n, poate fi afișată oricare
Exemplu:
Intrare 169
Ieșire 25 144
Rezolvare
<syntaxhighlight lang="python" line> import math
def validare_date(n):
"""Functie de validare""" if not 1 <= n <= 10**15: print("Numarul introdus trebuie sa fie intre 1 si 10^15.") return False return True
def sum_square(n):
ok = False for i in range(1, int(math.sqrt(n // 2)) + 1): x = i * i y = n - x j = int(math.sqrt(y))
if j * j == y and not ok: print(min(y, x), max(x, y)) ok = True
if not ok: print("NU")
if __name__ == '__main__':
n = int(input()) if validare_date(n): print("Date de intrare valide") sum_square(n) else: print("Date de intrare invalide") </syntaxhighlight>