2611 - Raza
De la Universitas MediaWiki
Cerinţa
Avem la dispoziție un chenar dreptunghiular format din oglinzi. O rază de lumină pornește din colțul stânga jos al dreptunghiului sub un unghi de 45 de grade față de latura de jos a dreptunghiului și lovește latura de sus sau latura din dreapta. Aici se reflectă (pornește spre o altă latură tot sub un unghi de 45 de grade față de latura de care s-a lovit). Își continuă drumul până când ajunge într-un colț al dreptunghiului.
Date de intrare
Programul citește de la tastatură dimensiunile chenarului a și b.
Date de ieşire
Programul va afișa pe ecran numărul de atingeri ale marginilor chenarului. Punctul de pornire și cel final nu se numără.
Restricții și precizări
- dim1, dim2 ∈ Ν
- 1 ⩽ dim1, dim2 ⩽ 2.000.000.000
Exemplu1
- Intrare
- 3 8
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 9
Exemplu2
- Intrare
- 8 4
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 1
Rezolvare
def validare_date(dim1, dim2):
if 0 < int(dim1) <= 2_000_000_000 and 0 <= int(dim2) <= 2_000_000_000:
return True
return False
def raza(dim1, dim2):
n, m = dim1, dim2
while dim2:
r = dim1 % dim2
dim1 = dim2
dim2 = r
numar_atingeri = n // dim1 + m // dim1 - 2
print(numar_atingeri)
if __name__ == '__main__':
dim1, dim2 = map(int, input().split())
if validare_date(dim1, dim2):
print("\nDatele de intrare corespund restrictiilor impuse.\n")
raza(dim1, dim2)
else:
print("Datele de intrare nu corespund restrictiilor impuse.")