Monday, 15 February 2016

Program to take input of a number and check whether it is a Smith number

Write a program to take input of a number and check whether it is a Smith number or not.


import java.util.Scanner;

public class Test {
    public static void main(String[] args) {   
       Scanner sc=new Scanner(System.in);
       System.out.print("Enter a number: ");
       int num = sc.nextInt();
       
       
     
       
        if(isSmithNumber(num)){
            System.out.println(num+" is Smith Number");
        }else{
            System.out.println(num+" is not Smith Number");

        }
    }
   
   
    public static boolean isSmithNumber(int num) {

        int sumOfDigits = getSumOfDigits(num);

        int sumOfPrimeFactors = getSumOfPrimeFactors(num);

        if (sumOfDigits == sumOfPrimeFactors) {
            return true;
        } else {
            return false;

        }

    }
   
   

    public static int getSumOfPrimeFactors (int num){       
      int sum=0;
     
      int numCopy = num;
     
      int divisor=2;     
      while(divisor<numCopy && divisor>1){
          if(num%divisor==0){
              sum = sum + getSumOfDigits(divisor);
              num=num/divisor;
              divisor--;
          }
          divisor++;
      }
     
      return sum;
     
    }
   
    public static int getSumOfDigits (int num){       
        int sum = 0;

        while (num > 0) {
            int digit = num % 10;
            sum = sum + digit;
            num = num / 10;
        }

        return sum;

    }
   
}

No comments:

Post a Comment