Program C ++ ke kontrole Armstrongova čísla

V tomto příkladu se naučíte zkontrolovat, zda je číslo zadané uživatelem číslem Armstrong nebo ne.

Abychom porozuměli tomuto příkladu, měli byste znát následující programovací témata C ++:

  • C ++ if, if … else a Nested if … else
  • C ++ zatímco a dělat … zatímco Loop

Kladné celé číslo se nazývá Armstrongovo číslo (řádu n), pokud

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

V případě Armstrongova počtu 3 číslic se součet kostek každé číslice rovná číslu samotnému. Například 153 je Armstrongovo číslo, protože

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

Příklad: Zkontrolujte Armstrong počet 3 číslic

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

Výstup

 Zadejte kladné celé číslo: 371 371 je Armstrongovo číslo.

V programu procházíme smyčkou while, dokud není originalNum 0.

V každé iteraci smyčky se k výsledku přidá krychle poslední číslice orignalNum.

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

A poslední číslice je odstraněna z orignalNum.

Když smyčka končí, je ve výsledku uložen součet krychle jednotlivých číslic.

Příklad: Zkontrolujte Armstrong Počet n číslic

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

Výstup

 Zadejte celé číslo: 1634 1634 je Armstrongovo číslo.

V tomto programu se nejprve vypočítá počet číslic zadaného čísla a uloží se do n.

A je pow()funkce vypočítá sílu jednotlivých číslic v každém opakování whilesmyčky.

Zajímavé články...