/* A Smith number is a composite number, the sum of whose digits is the sum of the digits of its prime
* factors obtained as a result of prime factorization(excluding 1).
* ex- 666 is a Smith Number -->prime factors --> 2,3,3,37
* sum of the digits=6+6+6=18
* sum of the digits of the factors=2+3+3+3+7=18
*/
import java.util.*;
class smith
{//class smith opens
int sumdigit(int n)//method to find the sum of the digits
{
int s=0;
while(n>0)
{
s=s+(n%10);//10
n=n/10;
}
return s;
}
int sumprimefact(int n)//method to find the sum of the prime factors
{
int i=2,sum=0;
while(n>1)//666>1 t
{
if(n%i==0)//666%2==0 t//37%37==0 t
{
sum=sum+sumdigit(i);//0+2+3+3+10=18
n=n/i;
}
else
i++;
}
return sum;
}
public static void main(String[]args)
{//main method opens
Scanner sc=new Scanner(System.in);
smith obj=new smith();
System.out.println("Enter a no");
int n=sc.nextInt();//666
int a=obj.sumdigit(n);//18
int b=obj.sumprimefact(n);//18
System.out.println("Sum of the digits= "+a);//18
System.out.println("Sum of the prime factors= "+b);//18
if(a==b)//18==18 true
System.out.println("It is a smith no");
else
System.out.println("It is not a smith no");
}//main method closes
}//class closes
No comments:
Post a Comment
any problem in any program comment:-