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

Losowy wynik przy pierwszej kompilacji

Object Storage Arubacloud
0 głosów
128 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,290 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,460 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 1,153 wizyt
pytanie zadane 19 stycznia 2021 w C i C++ przez Flaven Początkujący (320 p.)
0 głosów
0 odpowiedzi 266 wizyt
pytanie zadane 4 stycznia 2022 w C i C++ przez Arkadiusz Grządziel Nowicjusz (120 p.)
+1 głos
3 odpowiedzi 2,201 wizyt
pytanie zadane 10 kwietnia 2015 w C i C++ przez figorin Bywalec (2,040 p.)

92,570 zapytań

141,422 odpowiedzi

319,643 komentarzy

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

...