1858 - Rest Mare: Difference between revisions
Dragos1234 (talk | contribs) |
Dragos1234 (talk | contribs) |
||
Line 4: | Line 4: | ||
== Date de intrare == | == Date de intrare == | ||
Fișierul de intrare restmare.in conține pe prima linie numărul '''n'''. | |||
== Date de ieșire == | == Date de ieșire == |
Revision as of 13:59, 2 April 2023
Sursa: [1]
Cerinţa
Pentru un număr natural m numim rest mare cel mai mare rest pe care îl obţinem împărţind numărul m la toate numerele naturale de la 1 la m. Fiind dat un număr natural n, se determină pentru fiecare număr de la 1 la n numărul rest mare, iar aceste resturi mari se însumează. Se cere aflarea acestei sume.
Date de intrare
Fișierul de intrare restmare.in conține pe prima linie numărul n.
Date de ieșire
Programul va afișa pe ecran numărul ct, reprezentând numărul cerut.
Restricţii şi precizări
- t poate fi 1 sau 2
- 1 ⩽ n ⩽ 1.000.000.000
- 2 ⩽ c1, c2, c3 ⩽ 9
- oricare două cifre sunt prime intre ele
Exemplul 1
- Intrare
- Introduceți cerința:
1
- Introduceți numărul total:
10
- Introduceți a:
2
- Introduceți b:
3
- Ieșire
- Rezultatul este: 3
Exemplul 2
- Intrare
- Introduceți cerința:
2
- Introduceți numărul total:
10
- Introduceți a:
3
- Introduceți b:
5
- Introduceți c:
7
- Ieșire
- Rezultatul este: 4
Rezolvare
<syntaxhighlight lang="python" line>
- 1858
def calculeaza_restmare(n):
k = n // 2 if n % 2 == 1: return k * k else: return k * (k - 1)
def validate(n):
if n < 1 or n > 2000000000: print("Valoarea citita nu se incadreaza in intervalul permis.") exit()
if __name__ == '__main__':
with open("restmare.in") as f: n = int(f.readline().strip()) validate(n)
rezultat = calculeaza_restmare(n)
with open("restmare.out", "w") as f: f.write(str(rezultat))
</syntaxhighlight>