Cerința
Avem la dispoziție o masa de biliard dreptunghiulara. O bila pornește din colțul stânga jos al dreptunghiului sub un unghi de 45 grade față de latura de jos a dreptunghiului și lovește latura de sus sau latura din dreapta. Aici ricoșează (pornește spre o altă latură tot sub un unghi de 45 grade față de latura de care s-a lovit). Își continuă drumul până când ajunge într-un colț al dreptunghiului.
Scrieți un program care calculează de câte ori (nrSchimb) mingea își schimbă direcția de mers până când se oprește într-un colț. Punctul de pornire nu se numără.
Date de intrare
Programul citește de la tastatură numerele a b reprezentând lungimea respectiv lățimea mesei.
Date de ieșire
Programul va afișa pe ecran numărul nrSchimb.
Restricții și precizări
1 ≤ a,b ≤ 10.000
Exemplu
Intrare
8 3
Ieșire
9
Explicație
De 4 ori lovește latura de sus, o dată latura din stânga și din dreapta și de 3 ori latura de jos și intră în colțul dreapta-jos.
#include <bits/stdc++.h>
using namespace std;
int main()
{
int a , b;
cin >> a >> b;
int n = a , m = b;
while(b)
{
int r=a%b;
a=b;
b=r;
}
cout << n/a+m/a-2;
return 0;
}