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

Co robię nie tak z czasem?

Object Storage Arubacloud
+1 głos
276 wizyt
pytanie zadane 5 lipca 2015 w C i C++ przez k222 Nałogowiec (30,150 p.)
Wziąłem się ostatnio za filmik z rekurencją z kursu c++ na yt i za poruszany tam problem silni. Robiłem więc program obliczający silnię przy pomocy fpętli i rekurencji, nawet jak chwile przysiadłem to wyszedł  - więc chciałem (tak jak w filmiku było zasugerowane) porównać szybkość działania pęntli do rekurencji. I z tym  pojawił się problem.

Wróciłem do filmiku ze wskaźnikami i niby wszystko zrobiłem dobrze ale jak odpalam program to wyświetla się  0. Czy mógłby mnie ktoś poprawić kto wie jak to się robi:

#include<iostream>
#include<time.h>
#include<cstdlib>

using namespace std;

long int silnia( int n )
{
    if( n == 0 ) return 1;
    else return n * silnia ( n - 1 );
};

long int s ( int m )
{
int wynik = 1;
for (int i=1;i<=m;i++)
{
wynik*=i;
}
return wynik;
};
//*****************************************************************************************************

int main()
{
    int x;
    clock_t start, stop, st , t;
    double czas , c;
    cout<<"Podaj liczbe, ktorej wynikiem ma byc jej silnia: "<<endl;
    cin>>x;
    start = clock();
    cout<<silnia(x)<<endl;
    stop = clock();
    czas = (double)(stop - start) / CLOCKS_PER_SEC;
    cout<<"Czas pracy przy rekurencji: "<<czas<<endl;
    st = clock();
    cout<<s(x)<<endl;
    t = clock();
    c = (double)(t - st) / CLOCKS_PER_SEC;
    cout<<"Czas pracy z uzyciem petli: "<<c<<endl;
    
    return 0;
}

1 odpowiedź

+2 głosów
odpowiedź 5 lipca 2015 przez Buby Pasjonat (19,590 p.)
wybrane 14 lipca 2015 przez k222
 
Najlepsza

Najprawdopodobniej dane które podajesz są zbyt małe, aby wymagały konkretnego czasu. Przykładowo, kiedy testowałem twój kod, to u mnie podanie wartości większej niż 14 powodowało wyjście poza zakres zmiennej long int. Kiedy zmieniłem deklarację obu funkcji na unsigned long long dla wartości 30 uzyskałem satysfakcjonujący wynik - różny od zera.

Oto fragment kodu, który zmieniłem:

unsigned long long silnia( int n )
{
    if( n == 0 ) return 1;
    else return n * silnia ( n - 1 );
};

unsigned long long s ( int m )
{
    long long wynik = 1;
    for( int i = 1; i <= m; i++ )
        wynik *= i;
        
    return wynik;
};

A tutaj output:

 

Podobne pytania

0 głosów
1 odpowiedź 379 wizyt
0 głosów
4 odpowiedzi 2,159 wizyt
pytanie zadane 15 października 2015 w C i C++ przez grzecho123 Początkujący (450 p.)
0 głosów
2 odpowiedzi 355 wizyt
pytanie zadane 30 września 2015 w HTML i CSS przez Shiro Stary wyjadacz (10,300 p.)

92,579 zapytań

141,429 odpowiedzi

319,657 komentarzy

61,963 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!

...