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

Błąd kompilacji - ideone

VPS Starter Arubacloud
0 głosów
247 wizyt
pytanie zadane 16 grudnia 2022 w C i C++ przez Dani Obywatel (1,450 p.)

Witam, podczas kompilacji na ideone wypisuje mi, że jest błąd kompilacji dla n równego np. milion.

Czy wie ktoś w czym jest błąd?

#include <iostream>
#include <cmath>

using namespace std;
const int MAX = 1e6;
int sito[MAX + 7];

void sito_eratostenesa() {
    sito[0] = sito[1] = 1;
    for (int i = 2; i <= sqrt(MAX); ++i) {
        if (sito[i] == 1) continue;
        for (int j = i * i; j <= MAX; j+=i) {
            sito[j] = 1;
        }
    }
}

int main()
{
    int n;
    cin >> n;
    sito_eratostenesa();
    //cout << sito[1000000] << endl;
    int ind = 1,i=2;
    while (ind <= n && i <= MAX) {
        if (sito[i] == 0) {
            cout << ind << ". " << i << '\n';
            ++ind;
        }
        ++i;
    }
    return 0;
}

 

komentarz 16 grudnia 2022 przez Oscar Nałogowiec (29,290 p.)
Mógłbyś podawać więcej informacji - jaki błąd i gdzie (w której linii)?
komentarz 16 grudnia 2022 przez Dani Obywatel (1,450 p.)

Przesyłam screena:

komentarz 16 grudnia 2022 przez Oscar Nałogowiec (29,290 p.)
Po pierwsze to nie bład kompilacji tylko wykonania - co oznacza że program dał się skompilować bez błędu, jednak napotkał bład po uruchomieniu. Warto to rozróżniać. Warto też rozróżniać błędy kompilacji od błedów linkowania, ale to później, jak będziesz pisał większe programy.

Po drugie - to nie jest problem ze stosem,w programie tablica jest allokowana statycznie. (zmienna globalna).

Po trzecie - skoro zapisujesz tylko 0 lub 1 do tablicy to nie musi być tablicą intów a char lub bool. Będzie ze 4  mniejsza.

Po czwarte - kiedyś puściłem analogiczny program na Odrze1305. Liczyła 15 minut. Na dzisiejszych kompach to ułamek sekundy, ale jednak sito erastostenesa to kupa roboty.

Po piate - SOA#1 (stadrardowa odpowiedź administratora #1) - u mnie działa. Co nie oznacza że program jest bezbłędny - drobne przekroczenia tablic mogą przejść "bezkarnie".

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 102 wizyt
pytanie zadane 23 marca 2022 w C i C++ przez SimiVoid Pasjonat (19,790 p.)
0 głosów
2 odpowiedzi 390 wizyt
pytanie zadane 18 sierpnia 2019 w C i C++ przez Mavimix Dyskutant (8,390 p.)
0 głosów
0 odpowiedzi 349 wizyt

92,455 zapytań

141,263 odpowiedzi

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

...