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

SPOJ liczby pierwsze C++

Mały hosting, OGROMNE możliwości
0 głosów
745 wizyt
pytanie zadane 4 kwietnia 2017 w SPOJ przez Kurogami12 Bywalec (2,610 p.)
Link do ćwiczenia: http://www.spoj.com/problems/PRIME1/ czyli - program ma za zadanie generować liczby pierwsze i faktycznie - działa , tyle że od 1 do 1 000 000 000 zajmuje to no.. sporo więcej czasu niż jest dostępny. Wykorzystałem tutaj sito eratostenesa, jednak nie mam pojęcia jak mógłbym sprawić żeby program działał szybciej. teraz drobny spojler jak ja to zrobiłem (tya..)

int sito(bool *tab,  int max)    //tab wskazuje na tablice bool, max to liczba do której ma być sprawdzane
{
    int licznik;         //to jest do pętli while
    for (int i=2; i<sqrt(max); i++)    //tutaj chyba wszystko jest jasne

    {
        if(tab[i-2]==true)    //tutaj żeby pętla faktycznie się wykonywała tylko dla liczb pierwszych
    {
        licznik=i+i;
        while(licznik<max)    //pętla while jest żeby pozbywać się liczb które pierwsze nie są
        {
            tab[licznik-2]=false;        //"wykreśla" liczby pierwsze
            licznik+=i;  
        }
            }
        }
}

Byłbym niezmiernie wdzięczny jakby ktoś mnie naprowadził na właściwe tory ewentualnie wytknął błąd.

1 odpowiedź

–2 głosów
odpowiedź 29 kwietnia 2017 przez Galit Początkujący (280 p.)
Ja do tego wziąłem się od innej strony pomyślałem że może ifem da się to rozwiązać ale się nie da xD

#include <iostream>

using namespace std;

int n;

int main()
{
    cout << "Podaj liczbe, sprawdzimy czy jest to liczba pierwsza" << endl;
    cin >> n;

if ((n>1)&&(n/1)&&(n/n))
{
    cout <<"TAK";
}
else
{
    cout <<"NIE";
}
    return 0;
}
1
komentarz 29 kwietnia 2017 przez unknown Nałogowiec (39,560 p.)
if ((n>1)&&(n/1)&&(n/n))

Nawet nie pytam co ten if miał robić.

komentarz 29 kwietnia 2017 przez Galit Początkujący (280 p.)
Skoro nie pytasz to odpowiadam xD

W taki razie jak poprawie to zapisać, możesz inny przykład dać żebym sam na to wpadł ??

Podobne pytania

0 głosów
2 odpowiedzi 813 wizyt
pytanie zadane 30 lipca 2019 w SPOJ przez wjacoszek2000 Początkujący (290 p.)
0 głosów
1 odpowiedź 1,408 wizyt
pytanie zadane 4 maja 2019 w SPOJ przez Psz3mo Mądrala (5,030 p.)
0 głosów
1 odpowiedź 328 wizyt
pytanie zadane 13 lutego 2021 w SPOJ przez Parex Nowicjusz (200 p.)

93,717 zapytań

142,629 odpowiedzi

323,261 komentarzy

63,262 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

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...