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

Bu örnekte, kullanıcı tarafından girilen bir sayı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, if… else ve Nested if… else
  • C ++ while ve do… Döngü sırasında

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

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

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 

Örnek: 3 Haneli Armstrong Sayısını Kontrol Edin

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

Çıktı

 Pozitif bir tam sayı girin: 371 371, bir Armstrong sayısıdır.

Programda, originalNum 0 olana kadar while döngüsünü yineliyoruz.

Döngünün her yinelemesinde, orignalNum'un son basamağının küpü sonuca eklenir.

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

Ve son rakam orignalNum.

Döngü sona erdiğinde, sonuçta tek tek rakamın küpünün toplamı saklanır.

Örnek: Armstrong Sayısının n Basamaklarını Kontrol Edin

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

Çıktı

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

Bu programda, girilen sayının hane sayısı önce hesaplanır ve n'de saklanır.

Ve pow()fonksiyon, whiledöngünün her yinelemesinde tek tek basamakların gücünü hesaplar .

Ilginç makaleler...