C ++ programa patikrinti Armstrongo skaičių

Šiame pavyzdyje išmoksite patikrinti, ar vartotojo įvestas skaičius yra „Armstrong“ numeris, ar ne.

Norėdami suprasti šį pavyzdį, turėtumėte žinoti šias C ++ programavimo temas:

  • C ++, jei, jei… dar kitaip, ir įdėta, jei … kita
  • C ++, o ir darykite … kol kilpa

Teigiamas sveikasis skaičius vadinamas Armstrongo skaičiumi (n eilės), jei

abcd… = a n + b n + c n + d n +…

Jei „Armstrong“ yra 3 skaitmenys, kiekvieno skaitmens kubelių suma lygi pačiam skaičiui. Pavyzdžiui, 153 yra Armstrongo skaičius, nes

 153 = 1 * 1 * 1 + 5 * 5 * 5 + 3 * 3 * 3 

Pavyzdys: patikrinkite Armstrongo 3 skaitmenų skaičių

 #include using namespace std; int main() ( int num, originalNum, remainder, result = 0; cout <> num; originalNum = num; while (originalNum != 0) ( // remainder contains the last digit remainder = originalNum % 10; result += remainder * remainder * remainder; // removing last digit from the orignal number originalNum /= 10; ) if (result == num) cout << num << " is an Armstrong number."; else cout << num << " is not an Armstrong number."; return 0; )

Rezultatas

 Įveskite teigiamą skaičių: 371 371 yra Armstrongo skaičius.

Programoje kartojame „while“ kilpą, kol „originalNum“ bus 0.

Kiekvienoje kilpos iteracijoje prie rezultato pridedamas paskutinio „orignalNum“ skaitmens kubas.

 remainder = originalNum % 10; result += remainder * remainder * remainder;

Paskutinis skaitmuo pašalinamas iš orignalNum.

Pasibaigus kilpai, rezultate išsaugoma atskiro skaitmens kubo suma.

Pavyzdys: patikrinkite Armstrongo n skaitmenų skaičių

 #include #include using namespace std; int main() ( int num, originalNum, remainder, n = 0, result = 0, power; cout <> num; originalNum = num; while (originalNum != 0) ( originalNum /= 10; ++n; ) originalNum = num; while (originalNum != 0) ( remainder = originalNum % 10; // pow() returns a double value // round() returns the equivalent int power = round(pow(remainder, n)); result += power; originalNum /= 10; ) if (result == num) cout << num << " is an Armstrong number."; else cout << num << " is not an Armstrong number."; return 0; )

Rezultatas

 Įveskite sveiką skaičių: 1634 1634 yra Armstrongo skaičius.

Šioje programoje pirmiausia apskaičiuojamas įvesto skaičiaus skaitmenų skaičius ir jis saugomas n.

Ir, The pow()funkcija apskaičiuoja atskirų skaitmenų galią kiekvienoje iteracijoje whilekilpa.

Įdomios straipsniai...