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

Kalkulator - spoj

Object Storage Arubacloud
0 głosów
339 wizyt
pytanie zadane 26 lutego 2018 w C i C++ przez justyna13.97 Nowicjusz (190 p.)

Mam problem z zadaniem ze spoj:

http://pl.spoj.com/problems/CALC/

Moje rozwiązanie:

https://pastebin.com/tKjk7bfN

 

Wyskakuje blad: błąd wykonania (SIGABRT). Wyniki testowane i zdają się być ok....Ale już widzę, że to chyba chodzi o problem ze wskaznikami. Zgadza się? Nie mam pojęcia jak to naprawić...Dopiero zaczynam nauke C++ i wydaje mi się, że nie do końca tak to się mogło robić....Ktoś, coś? ;)

ps. wybaczcie, że cały kod, ale nie jetem pewna gdzie leży błąd

1 odpowiedź

0 głosów
odpowiedź 26 lutego 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)

Daruj sobie te wskaźniki i alokację pamięci. Wejście i wyjście w spoju są oddzielone, więc nie trzeba wpisywać wyników do tablicy tylko po to, żeby je potem wypisać.

Co do kodu:

wynik = new int[i + 1];
wynik = tab_wynikow;

To jest kompletnie bez sensu. W pierwszej linii przypisujesz do zmiennej wynik obszar pamięci na (i+1) intów tylko po to, by w kolejnej linijce tą zmienną nadpisać i utracić dostęp do zaalokowanej pamięci. Inna sprawa, że ta zmienna nie jest nigdzie w kodzie używana.

Sam błąd wynika zapewne z wyjścia poza zakres tablicy. Zmienna tab_wynikow ma miejsce na jednego inta, więc już przy drugim obrocie pętli wychodzisz poza zakres.

W linijce 45 z kolei źle zwalniasz pamięć.

komentarz 26 lutego 2018 przez justyna13.97 Nowicjusz (190 p.)
Okej....Usunelam alokacje, dałam zwyczajne tab_wynikow[200] tak jak mowiles i zaakceptowane.

Tylko tak się zastanawiam...Jak by to trzeba było zmienić, żeby zrobić z alokacją pamięci?
komentarz 26 lutego 2018 przez Qwerty96 Stary wyjadacz (13,580 p.)

Do tego w ogóle nie trzeba żadnych tablic. Rozwiązanie tego powinno wyglądać tak:

while (std::cin >> znak >> a >> b) {
   std::cout << WykonajOperacje(znak, a, b) << '\n';
}

Oczywiście funkcję WykonajOperacje należy samemu zaimplementować.

komentarz 26 lutego 2018 przez justyna13.97 Nowicjusz (190 p.)
Rozumiem...Tylko zwyczajnie z ciekawości dla wiedzy jak używać wskaźników pytam ;)
komentarz 26 lutego 2018 przez justyna13.97 Nowicjusz (190 p.)
Przeglądałam już x razy, ale coś widać nie rozumiem. No nic, poczytam więcej, dzięki :)

Podobne pytania

0 głosów
1 odpowiedź 202 wizyt
pytanie zadane 12 maja 2019 w C i C++ przez CzekiBreki Nowicjusz (170 p.)
0 głosów
1 odpowiedź 259 wizyt
pytanie zadane 6 maja 2019 w C i C++ przez CzekiBreki Nowicjusz (170 p.)
0 głosów
1 odpowiedź 634 wizyt
pytanie zadane 22 lipca 2017 w C i C++ przez GaNdAlFf56 Początkujący (380 p.)

92,551 zapytań

141,399 odpowiedzi

319,529 komentarzy

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

...