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

Obzartuchy spoj- problem z kodem

Object Storage Arubacloud
0 głosów
179 wizyt
pytanie zadane 17 czerwca 2019 w C i C++ przez Tedi Użytkownik (580 p.)

Mam pytanko, a raczej prośbę o jakąś wskazówke. Dlaczego program w 1. części testu ze spoja dokonuje poprawnych obliczeń a w drugiej się wysypuje.

#include <iostream>
#include <cmath>

using namespace std;

int main()
{
    short ile;
    cout << "Ile testow: " ;
    cin>> ile;
    for (int i=1;i<=ile;i++)
    {
        double suma;
        int obzartuchy, pudelkociastek;
        cout<< "Ile obzartuchow na zlocie: "; cin>>obzartuchy;
        cout<< "Ile ciastek w pudelku: "; cin>>pudelkociastek;
        int czasy[obzartuchy];
        for(int j=1;j<=obzartuchy;j++)
        {
            cout<< "Podaj czas "<<j<<". obzartucha:";
            cin>>czasy[j];
            double x;
            x=floor(86400/czasy[j]);
            cout<< "Tyle ciastek na dobe: "<<x<<endl;

            double y;
            y=x/pudelkociastek;
            cout<< "Tyle pudelek na dobe: "<<y<<endl;


            suma+=y;


        }
        cout<<ceil (suma)<<endl;


    }

    return 0;
}

*wrzucając na spoja wyrzucam te couta i zbędne obliczenia ;)

1 odpowiedź

+1 głos
odpowiedź 17 czerwca 2019 przez RafalS VIP (122,820 p.)
short ile;

czemu short? integer bezpieczniejszy. Nie powiedzieli jak dużo testów może być.

int czasy[obzartuchy];

tak nie wolno. Długość tablicy musi być znana w momencie kompilacji. Działa tylko na niektórych kompilatorach. Napraw używając wektora lub dynamicznej alokacji.

int czasy[obzartuchy];
for(int j=1;j<=obzartuchy;j++)

wchodzisz poza zakres, tablica musi być na obzartuchy+1 jesli pętla startuje od 1.

double suma;
suma+=y;

użycie niezainicjowanej zmiennej, w której jest jakaś losowa wartość. Zainiciuj zerem.

komentarz 18 czerwca 2019 przez Tedi Użytkownik (580 p.)

Dzięki za pomoc, udało mi się to zrobić tak by spoj to zaakceptował. Przesyłam kod, jeśli dalej jest tam coś nie tak, to prosze o wskazówke ;D

 

#include <iostream>
#include <cmath>

using namespace std;



int main()
{
    int ile;
    cin>> ile;
    for (int i=1;i<=ile;i++)
    {
        double suma=0,x,y;
        int obzartuchy, pudelkociastek;
        cin>>obzartuchy;
        cin>>pudelkociastek;
        int*tab;
        tab=new int [obzartuchy];


        for(int j=0;j<obzartuchy;j++)
        {
            cin>>tab[j];

            x=86400/tab[j];
            y=x/pudelkociastek;
            suma+=y;
        }
        cout<<ceil(suma)<<endl;
        delete[]tab;


    }

    return 0;
}

 

Podobne pytania

0 głosów
1 odpowiedź 272 wizyt
pytanie zadane 19 maja 2019 w C i C++ przez kodowiec Początkujący (410 p.)
0 głosów
1 odpowiedź 168 wizyt
pytanie zadane 13 października 2021 w C i C++ przez Bubucziks Nowicjusz (220 p.)
0 głosów
2 odpowiedzi 219 wizyt
pytanie zadane 1 października 2022 w C i C++ przez Dani Obywatel (1,450 p.)

92,551 zapytań

141,396 odpowiedzi

319,527 komentarzy

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

...