Programa C para verificar el número Armstrong

En este ejemplo, aprenderá a verificar si un número entero ingresado por el usuario es un número Armstrong o no.

Para comprender este ejemplo, debe tener el conocimiento de los siguientes temas de programación en C:

  • C if … else Statement
  • C while y do… while Loop

Un entero positivo se llama número de Armstrong (de orden n) si

 abcd… = an + bn + cn + dn + 

En el caso de un número Armstrong de 3 dígitos, la suma de los cubos de cada dígito es igual al número en sí. Por ejemplo, 153 es un número de Armstrong porque

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

Compruebe el número de Armstrong de tres 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; ) 

Salida

 Ingrese un número entero de tres dígitos: 371 371 es un número de Armstrong. 

Compruebe el número de n dígitos de Armstrong

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

Salida

 Ingrese un número entero: 1634 1634 es un número de Armstrong. 

En este programa, el número de dígitos de un entero se calcula primero y se almacena en n. Y la pow()función se utiliza para calcular la potencia de dígitos individuales en cada iteración del segundo forciclo.

Articulos interesantes...