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

SPOJ: 626 obżartuchy - SIGABRT wskaźniki

Object Storage Arubacloud
0 głosów
155 wizyt
pytanie zadane 22 grudnia 2018 w C i C++ przez Natalia Hołub Nowicjusz (120 p.)

Rozwiązałam zadanie z użyciem tablic (zaakceptowane przez sędziego), potem zmodyfikowałam kod tak aby wykorzystać dynamiczne alokowanie pamięci i tu pojawia się problem - chociaż wszystko działa w kompilatorze, sędzia odrzuca rozwiązanie z komunikatem SIGABRT.

Nie mam pojęcia gdzie może być błąd,  proszę o wskazówkę.

#include <iostream>

using namespace std;

const int Sekund_na_dobe = 86400;

int main()
{
    int t, obzartuchy, ciastka_na_pudelko, suma_ciastek = 0;
    cin >> t;

    for (int i = 1; i <= t; i++)
    {
        cin >> obzartuchy >> ciastka_na_pudelko;

        int *czasy;
        czasy = new int [obzartuchy];

        for (int i = 0; i < obzartuchy; i++, czasy++)
        {
            cin >> *czasy;
            suma_ciastek += Sekund_na_dobe / *czasy;
        }

        if (suma_ciastek % ciastka_na_pudelko == 0)
            cout << suma_ciastek / ciastka_na_pudelko << endl;
        else
            cout << (suma_ciastek / ciastka_na_pudelko) + 1 << endl;

        delete [] czasy;
        suma_ciastek = 0;
    }

    return 0;
}

 

komentarz 22 grudnia 2018 przez monika90 Pasjonat (22,940 p.)
Do rozwiązania tego zadania nie są potrzebne tablice.

1 odpowiedź

+2 głosów
odpowiedź 22 grudnia 2018 przez RafalS VIP (122,820 p.)

delete[] musisz wywołać dokładnie na adresie zwróconym przez new, a Ty wywołujesz na adresie przesunietym o ilosc obzartuchow.

I nie wiem po co tak śmiesznie iterujesz po tablicy. Przy alokacji dynamicznej tablicy mozesz dalej wykorzystywac najzwyklejszy operator []:

czasy[i] = 0;

 

komentarz 22 grudnia 2018 przez Natalia Hołub Nowicjusz (120 p.)
Dziękuję, po poprawkach działa.

Podobne pytania

0 głosów
3 odpowiedzi 778 wizyt
pytanie zadane 29 sierpnia 2016 w C i C++ przez eighty Nowicjusz (190 p.)
0 głosów
0 odpowiedzi 265 wizyt
pytanie zadane 16 września 2019 w C i C++ przez magda_19 Gaduła (3,080 p.)
0 głosów
2 odpowiedzi 341 wizyt
pytanie zadane 21 lutego 2018 w C i C++ przez Admin Cpp Początkujący (350 p.)

92,575 zapytań

141,424 odpowiedzi

319,650 komentarzy

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

...