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

PRIME1 - Prime Generator - Zbyt długi czas działania programu

VPS Starter Arubacloud
0 głosów
263 wizyt
pytanie zadane 20 kwietnia 2018 w SPOJ przez Kamil Paradowski Użytkownik (620 p.)
zmienione kategorie 20 kwietnia 2018 przez Kamil Paradowski

Witam! Od kilku dni zmagam się z jednym zadaniem z anglojęzycznego SPOJ'a, jakim jest "Prime Generator"

Treść zadania: http://www.spoj.com/problems/PRIME1/

Moim problemem jest to, że program działa za długo i za każdym razem wywala komunikat time limit exceeded. Mój kod wygląda następująco:

#include <iostream>

void sieve_of_eratosthenes(unsigned int M,unsigned int N);

int main()
{
    unsigned int t,m,n;
    std::cin>>t;
    for (int i=0;i<t;++i)
    {
        std::cin>>m>>n;
        sieve_of_eratosthenes(m,n);
    }
    return 0;
}

void sieve_of_eratosthenes(unsigned int M,unsigned int N)
{
    bool numbers[N+1]={};
    for (int i=2;i*i<=N;++i)
    {
        if(!numbers[i])
        {
            for (int j=i*i;j<=N;j+=i)
                numbers[j]=1;
        }
    }
    for (int i=M;i<=N;++i)
    {
        if (!numbers[i] && i!=1)
            std::cout<<i<<std::endl;
    }
}

Czy ktoś mógłby mi doradzić co powinienem zmienić, abym mógł otrzymać wynik pozytywny? Dodam, że bardzo mi zależy, abym mógł uzyskać czas 0:00 (Celuje jak najwyżej :D)

komentarz 20 kwietnia 2018 przez Mariusz08 Maniak (62,300 p.)
Zła kategoria (SPOJ)
komentarz 20 kwietnia 2018 przez Kamil Paradowski Użytkownik (620 p.)
Poprawione, dziękuję.
komentarz 17 stycznia 2019 przez Mavannkas Bywalec (2,290 p.)

@Kamil Paradowski, Możesz spróbować zrobić to bez funkcji ponieważ każde odniesienie się do funkcji troche czasu zajmuje 

 

1 odpowiedź

0 głosów
odpowiedź 20 kwietnia 2018 przez dunaj Użytkownik (950 p.)
Tak na szybko:

Spróbuj zamienić cout na printf, bo wiem ze były takie zadania, w których te kilka nanosekund na każdy print robiło różnicę.
komentarz 20 kwietnia 2018 przez Kamil Paradowski Użytkownik (620 p.)
Nie działa
1
komentarz 20 kwietnia 2018 przez Hiskiel Pasjonat (22,830 p.)
zamian std::endl na "\n"

Podobne pytania

0 głosów
1 odpowiedź 546 wizyt
0 głosów
0 odpowiedzi 110 wizyt
pytanie zadane 11 maja 2019 w SPOJ przez BinaryMan Stary wyjadacz (12,620 p.)
+1 głos
2 odpowiedzi 1,209 wizyt

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...