fbpx

Problema #2371 – Biliard – Rezolvari PBInfo

de Mihai-Alexandru

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;
}
Comentarii

S-ar putea sa iti placa