Program C ++ za preverjanje Armstrongove številke

V tem primeru se boste naučili preverjati, ali je številka, ki jo vnese uporabnik, Armstrongova številka ali ne.

Če želite razumeti ta primer, morate poznati naslednje programske teme C ++:

  • C ++ if, if … else in ugnezdeni if ​​… else
  • C ++ while in do … while Loop

Pozitivno celo število se imenuje Armstrongova številka (reda n), če

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

V primeru 3-mestnega Armstronga je vsota kock vsake številke enaka samemu številu. Na primer, 153 je Armstrongova številka, ker

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

Primer: Preverite Armstrongovo števko s tremi števkami

 #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; )

Izhod

 Vnesite pozitivno celo število: 371 371 je Armstrongova številka.

V programu prehodimo skozi zanko while, dokler originalNum ni 0.

V vsaki ponovitvi zanke se v rezultat doda kocka zadnje številke orignalNum.

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

In zadnja številka je odstranjena iz orignalNum.

Ko se zanka konča, se v rezultat shrani vsota kocke posamezne številke.

Primer: Preverite Armstrongova števila n števk

 #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; )

Izhod

 Vnesite celo število: 1634 1634 je Armstrongova številka.

V tem programu se najprej izračuna število števk vnesenega števila in shrani v n.

In je pow()funkcija izračuna moč posameznih številk v vsaki ponovitvi whilezanke.

Zanimive Članki...