Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Задача C++, НОД

Featured Replies

Здравейте, моля някой ако може да напише срещу редовете коментари, за да може програмката да бъде обяснена, нейния алгоритъм :)

 

#include<iostream>
using namespace std;
int p,q;

int gcd(int a, int b)
{
int d=2, mind, multi=1;
if(a<b)
     mind=a;
     else
     mind=b;
while(d<=mind)
{
     if(a%d==0 && b%d==0)
     {
     a=a/d;
     b=b/d;
     multi=multi*d
     }
    else
    d++
}
return multi;
}

int main()
{
cin>>p>>q;
cout<<gcd(p,q);
return 0;
}   

И защо толкова сложно като може и по-просто?

#include<iostream>

using namespace std;

int gcd(int a, int b)
{
    while(b)
    {
        int t=b;
        b=a%b;
        a=t;
    }
    return a;
}

int main()
{
    int p,q;
    cin>>p>>q;
    cout<<gcd(p,q);
    return 0;
}

или пък само с изваждане

int gcd(int a, int b)
{
    while(а!=b)
    {
        if (a<b) b-=a;
        else a-=b;
    }
    return a;
}

 

Редактирано от ined (преглед на промените)

  • Автор

Това учител по информатика за 11 клас го е писал в математическа гимназия.

 

Ученето на програмен език (както и на всичко останало) не е като използването му за конкретна цел. В тази задача се прави обратното на написване на програмка. Да обясниш в коментара - кой елемент какво прави.

Ако погледнете разните математически задачи - "От точка А се движил автомобил ..., пък от т. Б, срещу първия се движи втори ..." много вероятно е да си зададете въпроса - тия къде са тръгнали да обикалят? И гориво хабят, и замърсяват, а никаква работа не вършат.

преди 3 часа, nadal4o написа:

Здравейте, моля някой ако може да напише срещу редовете коментари, за да може програмката да бъде обяснена, нейния алгоритъм :)

Ако сега някой ти свърши работата - как ще я караш по-нататък?

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.