Neste exemplo, você aprenderá a verificar se um número inteiro inserido pelo usuário é um número Armstrong ou não.
Para entender este exemplo, você deve ter conhecimento dos seguintes tópicos de programação C:
- Declaração C if … else
- C while e do … while Loop
Um número inteiro positivo é chamado de número Armstrong (de ordem n) se
abcd… = an + bn + cn + dn +
No caso de um número Armstrong de 3 dígitos, a soma dos cubos de cada dígito é igual ao próprio número. Por exemplo, 153 é um número de Armstrong porque
153 = 1 * 1 * 1 + 5 * 5 * 5 + 3 * 3 * 3
Verifique o número Armstrong de três dígitos
#include int main() ( int num, originalNum, remainder, result = 0; printf("Enter a three-digit integer: "); scanf("%d", &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) printf("%d is an Armstrong number.", num); else printf("%d is not an Armstrong number.", num); return 0; )
Resultado
Insira um número inteiro de três dígitos: 371 371 é um número Armstrong.
Verifique o número de Armstrong de n dígitos
#include #include int main() ( int num, originalNum, remainder, n = 0; float result = 0.0; printf("Enter an integer: "); scanf("%d", &num); originalNum = num; // store the number of digits of num in n for (originalNum = num; originalNum != 0; ++n) ( originalNum /= 10; ) for (originalNum = num; originalNum != 0; originalNum /= 10) ( remainder = originalNum % 10; // store the sum of the power of individual digits in result result += pow(remainder, n); ) // if num is equal to result, the number is an Armstrong number if ((int)result == num) printf("%d is an Armstrong number.", num); else printf("%d is not an Armstrong number.", num); return 0; )
Resultado
Insira um número inteiro: 1634 1634 é um número Armstrong.
Neste programa, o número de dígitos de um inteiro é calculado primeiro e armazenado em n
. E, a pow()
função é usada para calcular a potência de dígitos individuais em cada iteração do segundo for
loop.