Armstrong Numarasını Kontrol Etmek İçin C Programı

Bu örnekte, kullanıcı tarafından girilen bir tamsayının Armstrong numarası olup olmadığını kontrol etmeyi öğreneceksiniz.

Bu örneği anlamak için, aşağıdaki C programlama konuları hakkında bilgi sahibi olmalısınız:

  • C if… else İfadesi
  • C while and do … while Loop

Pozitif bir tamsayı, Armstrong numarası olarak adlandırılır (n sırasına göre)

 abcd… = an + bn + cn + dn + 

Armstrong sayısının 3 basamaklı olması durumunda, her basamağın küplerinin toplamı, sayının kendisine eşittir. Örneğin, 153 bir Armstrong numarasıdır çünkü

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

Üç basamaklı Armstrong sayısını kontrol edin

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

Çıktı

 Üç basamaklı bir tam sayı girin: 371 371, bir Armstrong numarasıdır. 

Armstrong sayısını kontrol edin n basamak

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

Çıktı

 Bir tam sayı girin: 1634 1634, bir Armstrong numarasıdır. 

Bu programda, önce bir tamsayının basamak sayısı hesaplanır ve saklanır n. Ve pow()fonksiyon, ikinci fordöngünün her yinelemesinde tek tek basamakların gücünü hesaplamak için kullanılır .

Ilginç makaleler...