Friday, August 20, 2010

Armstrong number also called Narcissistic numbers.





Definition: 

 Armstrong numbers are the sum of their own digits to the power of the number of digits.

In other words

An Armstrong number is an n-digit base b number such that the sum of its (base b) digits raised to the power n is the number itself.

And according to wikipedia 

In recreational number theory, a narcissistic number (also known as a pluperfect digital invariant (PPDI), an Armstrong number or a plus perfect number) is a number that is the sum of its own digits each raised to the power of the number of digits. This definition depends on the base b of the number system used, e.g. b = 10 for the decimal system or b = 2 for the binary system or 

For Example:
There are just four numbers, after unity, which are the sums of the cubes of their digits:


153 = 13 + 53 + 33
370 = 33 + 73 + 03
371 = 33 + 73 + 13
407 = 43 + 03 + 73.

1.Program to check for Armstrong Number

#include

//Prototype of all the function being used in the program

int number_of_digits(int give_number);
int check_armstrong(int given_number,int number_of_digits);
int power(int temp_var,int number_of_digits);

//Main function starts

int main()
{
int give_number,no_of_digits,flag;
printf("\nEnter the number you want to check for Armstrong\n");
scanf("%d",&give_number);
no_of_digits=number_of_digits(give_number);
flag=check_armstrong(give_number,no_of_digits);
flag?printf("\n%d is Armstron\n",give_number):printf("\n%d is not Armstrong number\n",give_number);
return 0;
}

//Function to check how many degits are there in the given number

int number_of_digits(int given_number)
{
int count=0,temp;
while(given_number>0)
{
temp=given_number%10;
given_number=given_number/10;
count++;
}
return count;
}

//Function to check that the number is Armstrong or not

int check_armstrong(int given_number,int number_of_digits)
{
int temp_var,clone_number,regenerate_number=0;
clone_number = given_number;
while(clone_number>0)
{
temp_var=clone_number%10;
regenerate_number=regenerate_number + power(temp_var,number_of_digits);
clone_number=clone_number/10;
}
if(regenerate_number==given_number)
return 1;
else
return 0;
}

//Function the calculate the power same as pow() function

int power(int temp_var,int number_of_digits)
{
int cal_power=1,i;
for(i=0;i
cal_power=cal_power*temp_var;
return cal_power;
}

2.Program to find Armstrong Number in a given range 

#include

//Prototype of all the function being used in the program

int number_of_digits(long int give_number);
int check_armstrong(long int given_number,long int number_of_digits);
int power(long int temp_var,long int number_of_digits);

//Main function starts

int main()
{
long int give_number,no_of_digits,flag;
printf("\n Enter the number you want to check\n");
for(give_number=1;give_number<9999999;give_number++)
{
no_of_digits=number_of_digits(give_number);
flag=check_armstrong(give_number,no_of_digits);
flag?printf("\nNumber %ld is Armstron\n",give_number):printf("");
return 0;
}
}

//Function to check how many degits are there in the given number

int number_of_digits(long int given_number)
{
long int count=0,temp;
while(given_number>0)
{
temp=given_number%10;
given_number=given_number/10;
count++;
}
return count;
}

//Function to check that the number is Armstrong or not

int check_armstrong(long int given_number,long int number_of_digits)
{
long int temp_var,clone_number,regenerate_number=0;
clone_number = given_number;
while(clone_number>0)
{
temp_var=clone_number%10;
regenerate_number=regenerate_number + power(temp_var,number_of_digits);
clone_number=clone_number/10;
}
if(regenerate_number==given_number)
return 1;
else
return 0;
}

//Function the calculate the power same as pow() function

int power(long int temp_var,long int number_of_digits)
{
long int cal_power=1,i;
for(i=0;i
cal_power=cal_power*temp_var;
return cal_power;
}

Note: On compiling if you get any error than check it may that html has converted the lass than and greater than symbol as its own tags and also please do proper formatting.  This program  has been compiled and checked on GCC.








Delicious add to del.icio.us saved by 0 users

 

Never feel bad if u loose some thing or do not get expected because "There is always a better option"