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

Losowy wynik przy pierwszej kompilacji

Hosting forpsi easy 1 pln
0 głosów
126 wizyt
pytanie zadane 27 stycznia 2022 w C i C++ przez Fran1z Nowicjusz (120 p.)
edycja 27 stycznia 2022 przez Fran1z

Otóż wykonywałem zadanie polegające na wyznaczeniu wartości 1. elementu ciągu oraz różnicy między kolejnymi elementami ciągu, np. dla danych :

4(długość ciągu)

* 1 * 3

odpowiedzią jest "0"(pierwszy element ciągu) i "1"(różnica między kolejnymi elementami ciągu).

Na pisałem więc w Code Blocks'ie wersja 17.12 w C++ taki kod:

#include <iostream>

using namespace std;
long long dc,wzl=0,wol,wpp,wdp;
long long pli,dli, rl;
///funkcja wyznaczająca wartość potęgi 10
long long pt(int y)
{
    long long z=1;
    for(int k=0;k<y;k++)
    {
        z=z*10;
    }
    return z;
}
///funkcja zamieniająca stringa na long long
long long kni(string a)
{
    long long x=0;
    if(a[0]!='-')
    {
        wdp=0;
        for(int j=18;j>=0;j--)
        {
            while(a[j]!='0'&&a[j]!='1'&&a[j]!='2'&&a[j]!='3'&&a[j]!='4'&&a[j]!='5'&&a[j]!='6'&&a[j]!='7'&&a[j]!='8'&&a[j]!='9')
            {
                j--;
                //cout<<"a[j] "<<a[j]<<endl;
            }

            x=x+pt(wdp)*(a[j]-48);
            wdp++;

            //cout<<"a[j] "<<a[j]<<endl;
            //cout<<"x "<<x<<endl;
        }
    }
    else
    {
        wdp=0;
        for(int j=19;j>0;j--)
        {

            while(a[j]!='0'&&a[j]!='1'&&a[j]!='2'&&a[j]!='3'&&a[j]!='4'&&a[j]!='5'&&a[j]!='6'&&a[j]!='7'&&a[j]!='8'&&a[j]!='9')
            {
                j--;
            }

            x=x+pt(wdp)*(a[j]-48);
            wdp++;
        }
        x=x-2*x;
    }
    return x;

}
string ec[2000000];
string pl,dl;
int main()
{

    cin>>dc;
    ///wyznaczenie pierwszych dwóch wiadomych elementów oraz "odległości" między nimi
    for(int i=0;i<dc;i++)
    {
        cin>>ec[i];
        if(wzl==1)
        {
            wol++;
        }
        if(ec[i]!="*")
        {
            if(wzl==0)
            {
                pl=ec[i];
                wpp=i;
            }
            if(wzl==1)
            {
                dl=ec[i];
            }
            wzl++;
        }

    }
    //cout<<"pl[x] "<<pl[12]<<endl;
    //int o=pl[0]-48;
    //cout<<o<<endl;
    ///zamiana dwóch pierwszych znanych liczb na long long
    pli=kni(pl);
    dli=kni(dl);
    //cout<<pli<<" "<<dli<<" "<<wol<<endl;
    ///końcowe obliczenia wyznaczające wynik
    rl=(dli-pli)/wol;
    cout<<pli-(rl*wpp)<<" ";
    cout<<rl;
    return 0;
}

Program śmigał jak trzeba, ale po odesłaniu kodu otrzymałem odpowiedź, iż nastąpił błąd wykonania, dodatkowo gdy wstawiłem kod do kompilatora online (https://www.onlinegdb.com/online_c++_compiler), przy pierwszej (i tylko pierwszej) kompilacji wynik był losowy.

Podejrzewam błąd w przeprowadzeniu zamiany ze stringa na long long, ale (jak pewnie widać) nie jestem zbyt doświadczony, więc nie wiem i proszę o pomoc.

komentarz 27 stycznia 2022 przez Oscar Nałogowiec (29,130 p.)
Trochę zagmatwany ten kod, a nie podałeś co on tak w ogóle ma robić. Nie analizowałem go dokładnie (nazwy funkcji i zmiennych masz mało mówiące), ale widać że konwertujesz napis "od tyłu", nie prościej będzie konwertować od przodu - weź kolejna cyfre, jeśli ok to aktualny_wynik *= 10; aktualny_wynik += cyfra;

Kody cyfr  są kolejne (z czego korzystasz w linii 31 i 49) więc po co porównywać z kodem każdej cyfry oddzielnie, w lini 25 warunek typu (x<'0' || x>'9') wystarczy. Jest w ctype.h funkcja/makro isdigit().

1 odpowiedź

+1 głos
odpowiedź 27 stycznia 2022 przez mokrowski Mędrzec (155,480 p.)
Myślę że żywisz nadzieję przyśpieszenia kodu przez krótkie nazwy zmiennych. Kod nieczytelny jest do d***. Nawet mimo komentarzy... A także dzięki nim... Nie możesz użyć pow(..) oraz strtoll(..) ? I po co to finezyjne przeplatanie funkcji definicjami globalnymi?

Podobne pytania

0 głosów
3 odpowiedzi 991 wizyt
pytanie zadane 19 stycznia 2021 w C i C++ przez Flaven Początkujący (320 p.)
0 głosów
0 odpowiedzi 180 wizyt
pytanie zadane 4 stycznia 2022 w C i C++ przez Arkadiusz Grządziel Nowicjusz (120 p.)
+1 głos
3 odpowiedzi 2,108 wizyt
pytanie zadane 10 kwietnia 2015 w C i C++ przez figorin Bywalec (2,040 p.)

92,113 zapytań

140,777 odpowiedzi

317,759 komentarzy

61,435 pasjonatów

Advent of Code 2023

Top 15 użytkowników

  1. 1004p. - Łukasz Eckert
  2. 992p. - Dawid128
  3. 941p. - Mikbac
  4. 923p. - rucin93
  5. 878p. - CC PL
  6. 860p. - TheLukaszNs
  7. 856p. - Eryk Andrzejewski
  8. 841p. - nidomika
  9. 818p. - sefirek
  10. 785p. - the Bielsky
  11. 755p. - ikarek-one
  12. 749p. - Michal Drewniak
  13. 726p. - Arkadiusz Waluk
  14. 715p. - adrian17
  15. 713p. - Henry Saele
Szczegóły i pełne wyniki

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.

Uwaga - w dniach od 02.12 do 08.12 trwają Mikołajki (książki drukowane mają rabat -35%, ebooki do -45%). Zaś dodatkowy, specjalny kod zniżkowy: HELMIKOLAJ-10 dla naszych Widzów zapewni Wam oszczędność -10zł dla zamówień powyżej 70zł! Warto korzystać!

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!

...