I det här exemplet lär du dig att kontrollera om ett nummer som användaren anger är ett Armstrong-nummer eller inte.
För att förstå detta exempel bör du ha kunskap om följande C ++ programmeringsämnen:
- C ++ if, if… else och Nested if … else
- C ++ medan och gör … medan Loop
Ett positivt heltal kallas ett Armstrong-tal (av ordning n) om
abcd … = a n + b n + c n + d n + …
När det gäller ett Armstrong-antal på tre siffror är summan av kuber av varje siffra lika med själva numret. Till exempel är 153 ett Armstrong-nummer på grund av
153 = 1 * 1 * 1 + 5 * 5 * 5 + 3 * 3 * 3
Exempel: Kontrollera Armstrong antal tre siffror
#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; )
Produktion
Ange ett positivt heltal: 371 371 är ett Armstrong-tal.
I programmet itererar vi genom while-slingan tills originalNum är 0.
I varje iteration av slingan läggs kuben till den sista siffran i orignalNum till resultatet.
remainder = originalNum % 10; result += remainder * remainder * remainder;
Och den sista siffran tas bort från orignalNum
.
När slingan slutar sparas summan av den enskilda siffrans kub i resultatet.
Exempel: Kontrollera Armstrong antal n siffror
#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; )
Produktion
Ange ett heltal: 1634 1634 är ett Armstrong-nummer.
I detta program beräknas antalet siffror i det inmatade numret först och lagras i n.
Och pow()
funktionen beräknar kraften för enskilda siffror i varje iteration av while
slingan.