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

Segmentation fault SPOJ

Object Storage Arubacloud
0 głosów
282 wizyt
pytanie zadane 16 marca 2018 w C i C++ przez Patryk01 Obywatel (1,270 p.)

Witam, po próbie dodania rozwiązania do SPOJ-a, wyskoczył mi błąd o nazwie "Segmentation fault". Byłby ktoś tak dobry i wytłumaczyłby mi co powinienem w kodzie zmienić/dopisać? Z góry dziękuję za odpowiedź, a poniżej kod ;)

#include <iostream>

using namespace std;
int a, suma, i;
int main() {
	int *tab = new int[i];
	suma = 0;
	for (i = 0; i > -1; i++)
	{
		cin >> a;
		tab[i] = suma;
		tab[i+1] = a;
		suma = tab[i] + tab[i+1];
		cout << suma << endl;
}

       delete[] tab;
	return 0;
}

 

1 odpowiedź

+1 głos
odpowiedź 16 marca 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)
for (i = 0; i > -1; i++)

Co to za jakiś dziwny warunek?

komentarz 16 marca 2018 przez Patryk01 Obywatel (1,270 p.)
Chciałem nieskończony warunek taki, aby miał w sobie i=0, żeby łatwiej przypisywać komórkom w tablicy liczby.
komentarz 16 marca 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)
edycja 16 marca 2018 przez Qwerty96
No więc masz powód swojego segmentation fault. W pewnym momencie i osiąga wartość większą od rozmiaru tablicy i przez to wychodzisz poza zakres.

EDIT: Teraz zauważyłem, że alokujesz tablicę o rozmiarze 0.
komentarz 16 marca 2018 przez Patryk01 Obywatel (1,270 p.)
Okej w takim razie jakiej pętli powinienem użyć? I czy powinienem w ogóle dynamicznie alokować pamięć?
komentarz 16 marca 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)
Jak dasz link do zadania, to może będę w stanie na to odpowiedzieć.
komentarz 16 marca 2018 przez Patryk01 Obywatel (1,270 p.)
komentarz 16 marca 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)
Do tego nie potrzebujesz żadnych tablic. Po prostu stwórz zmienną na przechowanie sumy, wczytaj liczbę, dodaj do sumy i wypisz sumę przy każdym obiegu pętli.
komentarz 16 marca 2018 przez Patryk01 Obywatel (1,270 p.)
Kurde faktycznie, tyle niepotrzebnego kodu. Dzięki wielkie, teraz jest mi o wiele łatwiej ;) A jaką utworzyłbyś pętlę? Nieskończoną? Bo wtedy wyskakuje, że przekroczono limit czasu..
komentarz 16 marca 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)
while (std::cin >> a) {...}
komentarz 16 marca 2018 przez Patryk01 Obywatel (1,270 p.)
Dzięki wielkie, działa ;)

Podobne pytania

+1 głos
1 odpowiedź 209 wizyt
pytanie zadane 17 lutego 2022 w C i C++ przez Yaqbek Nowicjusz (160 p.)
0 głosów
1 odpowiedź 474 wizyt
pytanie zadane 12 marca 2020 w C i C++ przez kvlike Nowicjusz (170 p.)
0 głosów
1 odpowiedź 461 wizyt
pytanie zadane 16 grudnia 2019 w C i C++ przez kvlike Nowicjusz (170 p.)

92,568 zapytań

141,420 odpowiedzi

319,622 komentarzy

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

...