3609 - Count Mod 10: Difference between revisions
Pagină nouă: == Cerința == Se dau două numere naturale nenule '''num1''' și '''num2''', unde '''num1 ⩽ num2'''. Să se determine câte numere naturale divizibile cu 10 sunt în intervalul '''[num1, num2]'''. == Date de intrare == Programul citește de la tastatură numerele '''num1''' și '''num2'''. == 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 de numere naturale divizib... |
No edit summary |
||
(2 intermediate revisions by the same user not shown) | |||
Line 7: | Line 7: | ||
În următorul rând se va afișa pe ecran numărul de numere naturale divizibile cu 10 din intervalul '''[num1, num2]'''. | În următorul rând se va afișa pe ecran numărul de numere naturale divizibile cu 10 din intervalul '''[num1, num2]'''. | ||
Î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 ⩽ '''num1''' ⩽ '''num2''' ⩽ 1000000000 | * 1 ⩽ '''num1''' ⩽ '''num2''' ⩽ 1000000000 | ||
Line 28: | Line 28: | ||
<syntaxhighlight lang="python" line> | <syntaxhighlight lang="python" line> | ||
# 3609 - countmod10 | # 3609 - countmod10 | ||
def | def validare(num1, num2): | ||
# Daca datele sunt invalide v-om face raise la eroarea ValueError | |||
if num1 >= 1 and num2 >= num1 and num2 <= 1000000000: | if not (num1 >= 1 and num2 >= num1 and num2 <= 1000000000): | ||
raise ValueError | |||
def countmod10(num1, num2): | |||
# Numarul de numere divizibile cu 10 din intervalul [num1, num2] | |||
# este egal cu x-y, unde: | |||
# x este numarul de numere divizibile cu 10 din intervalul [1, num2] | |||
# y este numarul de numere divizibile cu 10 din intervalul [1, num1-1] | |||
# x = num2 // 10 | |||
# y = (num1 - 1) // 10 | |||
numere_div_10 = num2 // 10 - (num1 - 1) // 10 | |||
print(numere_div_10) | |||
if __name__ == '__main__': | if __name__ == '__main__': | ||
countmod10() | # Citim de la tastatura numerele cerute | ||
num1 = int(input()) | |||
num2 = int(input()) | |||
# Verificam daca datele introduse sunt valide | |||
# daca nu afisam mesajul corespunsador | |||
try: | |||
validare(num1, num2) | |||
except ValueError: | |||
print("Nu au fost respectate cerintele impuse") | |||
else: | |||
print("Datele de intrare corespund restricțiilor impuse") | |||
countmod10(num1, num2) | |||
</syntaxhighlight> | </syntaxhighlight> |
Latest revision as of 11:12, 23 May 2023
Cerința[edit | edit source]
Se dau două numere naturale nenule num1 și num2, unde num1 ⩽ num2. Să se determine câte numere naturale divizibile cu 10 sunt în intervalul [num1, num2].
Date de intrare[edit | edit source]
Programul citește de la tastatură numerele num1 și num2.
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 de numere naturale divizibile cu 10 din intervalul [num1, num2].
Î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 ⩽ num1 ⩽ num2 ⩽ 1000000000
Exemplu 1[edit | edit source]
- Intrare
- 19
- 90
- Ieșire
- Datele de intrare corespund restricțiilor impuse
- 8
Exemplu 2[edit | edit source]
- Intrare
- 11
- 8
- Ieșire
- Nu au fost respectate cerintele impuse
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line>
- 3609 - countmod10
def validare(num1, num2):
# Daca datele sunt invalide v-om face raise la eroarea ValueError
if not (num1 >= 1 and num2 >= num1 and num2 <= 1000000000): raise ValueError
def countmod10(num1, num2):
# Numarul de numere divizibile cu 10 din intervalul [num1, num2] # este egal cu x-y, unde: # x este numarul de numere divizibile cu 10 din intervalul [1, num2] # y este numarul de numere divizibile cu 10 din intervalul [1, num1-1] # x = num2 // 10 # y = (num1 - 1) // 10 numere_div_10 = num2 // 10 - (num1 - 1) // 10
print(numere_div_10)
if __name__ == '__main__':
# Citim de la tastatura numerele cerute num1 = int(input()) num2 = int(input())
# Verificam daca datele introduse sunt valide # daca nu afisam mesajul corespunsador try: validare(num1, num2) except ValueError: print("Nu au fost respectate cerintele impuse") else: print("Datele de intrare corespund restricțiilor impuse")
countmod10(num1, num2)
</syntaxhighlight>