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

SPOJ liczby pierwsze C++

Object Storage Arubacloud
0 głosów
394 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 432 wizyt
pytanie zadane 30 lipca 2019 w SPOJ przez wjacoszek2000 Początkujący (290 p.)
0 głosów
1 odpowiedź 999 wizyt
pytanie zadane 4 maja 2019 w SPOJ przez Psz3mo Mądrala (5,030 p.)
0 głosów
1 odpowiedź 183 wizyt
pytanie zadane 13 lutego 2021 w SPOJ przez Parex Nowicjusz (200 p.)

92,555 zapytań

141,403 odpowiedzi

319,557 komentarzy

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

...