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

Błąd wykonania (SIGSEGV)

Object Storage Arubacloud
0 głosów
168 wizyt
pytanie zadane 26 lutego 2022 w C i C++ przez Rafek Nowicjusz (120 p.)

Cześć,

Zająłem się ostatnio zadaniem z SPOJ "Zabawne dodawanie Piotrusia".  link: https://pl.spoj.com/problems/BFN1/
Pomimo, że wyniki są poprawne wyskakuje błąd wykonania(SIGSEGV). Oto mój kod. Nie wiem czy błąd znajduje się w nim czy też nie.

#include <iostream>

using namespace std;

int t, n, licznik;

int rev(int number)
{
    int result = 0;
    do
    {
        result = result * 10 + number % 10;
    }while (number /= 10);

    return result;
}


int wykonaj(int x)
{
    int pal = rev(x); // pal = palindrom x
    if(x == pal) return x;
    licznik++;
    x += pal;
    wykonaj(x); //rekurencja
}


int main()
{
    cin >> t;
    while(t--)
    {
        cin >> n;
        licznik =0;
        cout << wykonaj(n) << " " << licznik << "\n";  //pokaz wynik
    }
}

 

komentarz 26 lutego 2022 przez Oscar Nałogowiec (29,290 p.)
Nie używasz żadnych wskaźników więc jedyną możliwością wystąppiecia SIGSEGV jest stos a konkretnie rekurencja. Dla jakiej wartości n występuje błąd? Jesteś pewny, że zawsze znajdziesz ten palindrom? I zmieści się on w int.
komentarz 26 lutego 2022 przez Whistleroosh Maniak (56,980 p.)

@Rafek,  uruchomiłem program samemu i w moim przypadku dostaje WA zamiast SIGSEGV

komentarz 26 lutego 2022 przez Whistleroosh Maniak (56,980 p.)

Porównałem też plaindromy, które Twój program wypisuje dla liczb od 1 do 80 z prawidłową listą liczb na OEIS i wszystko jest dobrze. Więc może jest gdzieś błąd w ilosci kroków

komentarz 26 lutego 2022 przez Oscar Nałogowiec (29,290 p.)

@Rafek, Nie zwracasz wyniku z tej rekurencyjnej funkcji.

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
2 odpowiedzi 333 wizyt
0 głosów
1 odpowiedź 385 wizyt
0 głosów
1 odpowiedź 209 wizyt
pytanie zadane 14 listopada 2016 w C i C++ przez Michał Flisikowski Początkujący (370 p.)

92,551 zapytań

141,393 odpowiedzi

319,523 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!

...