C ++ program za provjeru Armstrongova broja

U ovom ćete primjeru naučiti provjeriti je li broj koji je korisnik unio Armstrongov broj ili nije.

Da biste razumjeli ovaj primjer, trebali biste imati znanje o sljedećim temama programiranja na C ++:

  • C ++ ako, ako … drugo i ugniježđeno ako … drugo
  • C ++ while and do … while Loop

Pozitivni cijeli broj naziva se Armstrongov broj (reda n) ako

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

U slučaju Armstrongova broja od 3 znamenke, zbroj kocki svake znamenke jednak je samom broju. Na primjer, 153 je Armstrongov broj jer

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

Primjer: Provjerite Armstrongov broj od 3 znamenke

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

Izlaz

 Unesite pozitivan cijeli broj: 371 371 je Armstrongov broj.

U programu prelazimo kroz while petlju dok originalNum ne postane 0.

U svakoj iteraciji petlje dodaje se kocka posljednje znamenke orignalNum.

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

I, posljednja znamenka uklonjena je iz orignalNum.

Kada se petlja završi, zbroj kocke pojedinačne znamenke pohranjuje se u rezultat.

Primjer: Provjerite Armstrongov broj n znamenki

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

Izlaz

 Unesite cijeli broj: 1634 1634 je Armstrongov broj.

U ovom se programu prvo izračuna broj znamenki unesenog broja i pohrani u n.

A je pow()funkcija izračunava moć pojedinih znamenki u svakoj iteraciji u whilepetlji.

Zanimljivi članci...