• 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

42 Warsaw Coding Academy
0 głosów
374 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,280 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ź 611 wizyt
0 głosów
0 odpowiedzi 134 wizyt
pytanie zadane 11 maja 2019 w SPOJ przez BinaryMan Stary wyjadacz (12,620 p.)
+1 głos
2 odpowiedzi 1,534 wizyt

93,395 zapytań

142,389 odpowiedzi

322,569 komentarzy

62,754 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

VMware Cloud PRO - przenieś swoją infrastrukturę IT do chmury
...