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

DROBNY BŁĄD (prawdopodobnie); Program podaje nieodpowiedni wynik

0 głosów
461 wizyt
pytanie zadane 26 listopada 2019 w C i C++ przez xZenit Użytkownik (760 p.)
edycja 27 listopada 2019 przez xZenit

Witam,
mój program, który powinien wypisać na ekran wszystkie trzycyfrowe liczby, które spełniają warunek:
"suma sześcianów cyfr tej liczby jest równa tej liczbie" (przykład: 153=1^3+5^3+3^3); zamiast tego pokazuje kolejne liczby od 704 do 999. Dodam, że całość kompiluje się poprawnie.

Wiem, że są dużo prostsze sposoby stworzenia tego programu, ale sama struktura musi pozostać mniej więcej taka jak poniżej.

#include <iostream>
#include <cmath>
using namespace std;

int main()
{
   int s, d, j;

   for (s=1; s<=9; s)
   { d=0;
        while (d<=9)
        {j=0;
                while(j<=9)
                {
                    if ((100*s+10*d+j) == (pow(s, 3)+pow(d, 3)+pow(j, 3)));
                    {
                        cout<<100*s+10*d+j<<endl;
                    }
                j++;
                }

        d++;
        }

   s++;
   }
}

Czy ktoś mógłby może zasugerować jak ów powyższy błąd naprawić?

komentarz 27 listopada 2019 przez niezalogowany
no raczej nie tak ((100*s+10*d+j) == (pow(s, 3)+pow(d, 3)+pow(j, 3)))

bo 100*1+10*0+0==1+0+0;
komentarz 27 listopada 2019 przez xZenit Użytkownik (760 p.)
Warunek ułożony zgodnie zadaniem: "suma sześcianów cyfr tej liczby jest równa tej liczbie".
Nie każda liczba musi go spełniać.
komentarz 27 listopada 2019 przez niezalogowany
ok mój błąd
komentarz 27 listopada 2019 przez xZenit Użytkownik (760 p.)
Ok, nie ma sprawy. A wiesz może dlaczego program nie działa poprawnie?
komentarz 15 stycznia 2020 przez xZenit Użytkownik (760 p.)

@xZenit,

Tak btw, to błąd powodował najprawdopodobniej ów, ukazany poniżej średnik, na końcu warunku w if'ie.

if ((100*s+10*d+j) == (pow(s, 3)+pow(d, 3)+pow(j, 3)));

 

2 odpowiedzi

0 głosów
odpowiedź 15 stycznia 2020 przez mokrowski Mędrzec (158,960 p.)
#include <iostream>

// FIXME: Now,... digit sum...
unsigned sum_cube_digits(unsigned value) {
    unsigned sum = 0;
    while (value != 0) {
        unsigned last_digit = value % 10;
        sum += last_digit;
        value /= 10;
    }
    return sum;
}

int main() {
    for (auto value = 0U; value < 100; ++value) {
        std::cout << value << ": " << sum_cube_digits(value) << '\n';
    }
}

 

–1 głos
odpowiedź 27 listopada 2019 przez niezalogowany
edycja 27 listopada 2019

if ((100*s+10*d+j) == (pow(s, 3)+pow(d, 3)+pow(j, 3)))   tu-> ;

Edit:: ale sobie odpowiedziałem "na jedno z... ważne pytanie"

dlaczego   

dlaczego tak 

 if(...){
}
a nie tak
if 
{
}

 

komentarz 15 stycznia 2020 przez xZenit Użytkownik (760 p.)
Mógłbyś doprecyzować odpowiedź?
komentarz 15 stycznia 2020 przez niezalogowany
przy formowaniu domyślnym po ife masz średnik (którego tam nie powinno być), wiec nawias ci przeskoczy do nowej linii i łatwo znaleźć błąd (a nie powinno go być w nowej linii przy pierwszym sposobie formatowania).

Podobne pytania

0 głosów
2 odpowiedzi 707 wizyt
pytanie zadane 15 listopada 2020 w C i C++ przez MrCrow Nowicjusz (120 p.)
0 głosów
1 odpowiedź 390 wizyt
pytanie zadane 15 stycznia 2020 w C i C++ przez xZenit Użytkownik (760 p.)
0 głosów
1 odpowiedź 917 wizyt
pytanie zadane 30 marca 2016 w C i C++ przez Chajol Początkujący (290 p.)

93,720 zapytań

142,641 odpowiedzi

323,264 komentarzy

63,268 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

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...