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

Problem z zadaniem SPOJ - Dwie cyfry silni (przekroczono limit czasu)

Object Storage Arubacloud
0 głosów
3,180 wizyt
pytanie zadane 15 marca 2016 w C i C++ przez Majkel00 Nowicjusz (230 p.)

Witam serdecznie!

Mam mały problem z zadaniem "Dwie cyfry silni" SPOJa, wcześniej gdy wykonałem kod z silnią przeprowadzoną iteracyjnie, otrzymałem komunikat o przekroczeniu limitu czasu, postanowiłem więc napisać silnie rekurencyjnie, niestety nadal otrzymuję ten sam komunikat. Zdaję sobie sprawę, z tego iż silnia rośnie w zabójczym tempie, ale nie mam niestety pomysłu jak mógłbym uprościć ten kod jeszcze bardziej i co za tym idzie wpłynąć na jego szybkość wykonywania się. Prosiłbym o pomoc przy tym kodzie oraz jakieś wskazówki dotyczące przyspieszania programów w C++. Z góry dziękuje i pozdrawiam!

Oto mój kod:

#include <cstdlib>
#include <iostream>
using namespace std;

long long silnia(int n)
{
 if(n<2)
        return 1;
        return n*silnia(n-1);
}

int main()
{
    int t;
    cin >> t;
    int n;
    for(int i=0; i<t; i++)
        {
    cin>>n;
    cout << (silnia(n))%10 << " " << (((silnia(n))%100)-((silnia(n))%10))/10<< endl;
        };
 return 0;
}



 

1 odpowiedź

+2 głosów
odpowiedź 15 marca 2016 przez daan Pasjonat (17,640 p.)
Wskazówka, która właściwie jest kluczem do zadania : zbadaj co się dzieje z silnią gdy n > 10. Dodatkowo wydaje mi się, że niepoprawnie wypisujesz te liczby, w zadaniu jest o ile się nie mylę aby wypisać najpierw cyfrę dziesiątek (x%100)/10 a potem cyfre jedności (x%10).

Podobne pytania

0 głosów
1 odpowiedź 1,067 wizyt
pytanie zadane 19 października 2016 w C i C++ przez Paq_93 Początkujący (260 p.)
+1 głos
2 odpowiedzi 530 wizyt
pytanie zadane 1 marca 2016 w C i C++ przez cherubinek Nowicjusz (190 p.)
0 głosów
5 odpowiedzi 1,961 wizyt
pytanie zadane 7 lutego 2016 w C i C++ przez XPACK Początkujący (320 p.)

92,568 zapytań

141,424 odpowiedzi

319,634 komentarzy

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

...