• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Analiza programu

Object Storage Arubacloud
+1 głos
213 wizyt
pytanie zadane 17 lutego 2021 w C i C++ przez maciej22 Nowicjusz (130 p.)
#include <cstdlib>
#include <iostream>
#include <iomanip>

using namespace std;

int rek(int a,int b)
{
   if(a==b) return a;
   else if(a>b) return rek(a-b,b);
   else return rek(a,b-a);
}
int main ()
{
   int x,y;
   cout <<"Podaj 2 liczby ";
   cin >> x;
   cout <<endl;
   cin >>y;
   cout <<endl;
   cout <<"NWD wynosi " << rek(x,y);
   cout << "\n";

system ("pause");
return 0;
}
#include<iostream>
using namespace std;

int NWD(int a, int b)
{
    while(a!=b)
       if(a>b)
           a-=b;
       else
           b-=a;
    return a;
}

int main()
{
    int a, b;

    cout<<"Podaj dwie liczby: ";
    cin>>a>>b;

    cout<<"NWD("<<a<<","<<b<<") = "<<NWD(a,b)<<endl;

    return 0;
}

Przeanalizowałby mi ktoś linijka po linijce ten program? Bardzo mi to potrzebne.

komentarz 18 lutego 2021 przez VBService Ekspert (253,340 p.)

laugh

#include<iostream>
using namespace std;
 
int NWD(int a, int b)
{
    while(a!=b)
       if(a>b) a-=b;
       else b-=a;
       
    return a;
}

int NWD_Recursion(int a, int b)
{
   if(a==b) return a;
   else if(a>b) return NWD_Recursion(a-b, b);
   else return NWD_Recursion(a, b-a);
}
 
int main()
{
    int a, b;
 
    cout << "Podaj dwie liczby: ";
     cin >> a >> b;
 
    cout << "\nObliczenie NWD - petla while\n"
         << "NWD(" << a << "," << b << ") = " << NWD(a, b) << endl;
         
    cout << "\nObliczenie NWD - rekurencyjne wywolanie funkcji\n"
         << "NWD(" << a << "," << b << ") = " << NWD_Recursion(a, b) << endl;         
 
    return 0;
}

 

1 odpowiedź

+2 głosów
odpowiedź 17 lutego 2021 przez KumberTwo Dyskutant (8,270 p.)

Pierwszy program oblicza NWD rekurencyjnie, korzystając z algorytmu Euklidesa. Sprawdza czy a = b, jeśli tak to kończy rekurencję i zwraca a, jeśli nie to funkcja powtarza się, tylko gdy a > b to dla argumentów a-b i b a jeśli to b > a to funkcja powtórzy się z argumentami a, b-1. Druga funkcja oblicza NWD w pętli dopóki a będzie różne od b. Najpierw sprawdza czy a > b, jeśli tak to zmniejsza a o b, jeśli nie to zmniejsza b o a. Na koniec zwraca a, które jest wynikiem. Pewnie nie wyjaśniłem tego najlepiej więc polecam przeczytać ten artykuł. Mam nadzieję że pomogłem choć trochę :)

Podobne pytania

0 głosów
1 odpowiedź 692 wizyt
pytanie zadane 27 sierpnia 2016 w C i C++ przez Itan Początkujący (250 p.)
0 głosów
1 odpowiedź 430 wizyt
pytanie zadane 27 sierpnia 2016 w C i C++ przez Itan Początkujący (250 p.)
0 głosów
1 odpowiedź 537 wizyt
pytanie zadane 16 sierpnia 2016 w C i C++ przez Itan Początkujący (250 p.)

92,572 zapytań

141,422 odpowiedzi

319,644 komentarzy

61,959 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...