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

Heap Corruption Detected SPOJ Tablice

VPS Starter Arubacloud
0 głosów
197 wizyt
pytanie zadane 12 września 2022 w C i C++ przez Nahlfar Nowicjusz (220 p.)

Próbuję rozwiązać zadanie bardzo proste co do pryncypiów i generalnie mój program podaje prawidłowe odpowiedzi, ale w trakcie wykonania na ostatniej linii wyskakuje: Heap Corruption Detected: after Normal block.

Ostatnia linia to delete dynamicznej tablicy. Dlaczego ten delete może wyrzucać błędy? Podczas kompilacji na SPOJ otrzymuję SIGABRT. Poniżej mój kod:

int main()
{
    int t, n;
    int* tab;
    cin >> t;
    for (int i = 0; i < t; i++)
    {
        cin >> n;
        tab = new int[n - 1];
        for (int j = 0; j < n; j++) cin >> tab[j];
        for (int j = n-1; j >= 0; j--) cout << tab[j] << " ";
        cout << "\n";
        delete[] tab;
    }
}

 

1 odpowiedź

0 głosów
odpowiedź 12 września 2022 przez j23 Mędrzec (194,920 p.)
wybrane 13 września 2022 przez Nahlfar
 
Najlepsza

Dlaczego ten delete może wyrzucać błędy?

Dlatego, że w pierwszej wewnętrznej pętli zapisujesz poza zakresem tablicy tab(a w następnej czytasz poza zakresem, choć to nie powoduje wspomnianego błędu, ale błędem jest).

komentarz 13 września 2022 przez Nahlfar Nowicjusz (220 p.)
Ok, dzięki. Usunałem -1 z deklaracji tab = new int[n - 1]; i już zadziałało.

Myślałem, że tablica ma n+1 elementów, ponieważ liczymy też element zerowy... A tutaj zaskoczenie... Czyli tablica ma n+1 elementów przy deklaracji tab[n], czy też dokładnie n?
komentarz 13 września 2022 przez j23 Mędrzec (194,920 p.)

No liczymy element zerowy, dlatego maksymalny indeks to n - 1, gdzie n to ilość elementów w tablicy.

Podobne pytania

0 głosów
0 odpowiedzi 169 wizyt
pytanie zadane 2 listopada 2021 w C i C++ przez DrTomas Nowicjusz (140 p.)
0 głosów
1 odpowiedź 607 wizyt
0 głosów
1 odpowiedź 306 wizyt
pytanie zadane 29 maja 2019 w C i C++ przez Mateusz Banaszak Nowicjusz (160 p.)

92,453 zapytań

141,262 odpowiedzi

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

...