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

SPOJ liczby pierwsze C++

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

92,452 zapytań

141,262 odpowiedzi

319,079 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!

...