Perfect Number:
A Perfect number is a positive integer that is equal to the sum of its proper divisors excluding the number itself.
For Example: Take Number 6. Its divisors are 1, 2 , 3 and 6. When we add all divisors except 6 ( as it is number itself) (i.e. 1+2+3= 6), it is equal to actual number. So we can say Number 6 is a perfect number.
The smallest perfect number is 6. Other perfect numbers are 28, 496, and 8,128.
Logic:
- When we divide a number say X by other number say Y and reminder is zero, then number Y is a proper divisor. All proper divisor of a number X are between 1 and X/2. ( 1 and X/2 are included) . To find the proper divisor we need to divide the number by 1 to number/2.
- We need to keep adding all divisors.
Java Program:
package StringPrograms; import java.util.Scanner; public class PerfectNumber { public static void perfectNumber(int userInput) { // Handling numbers less than or equal to zero if(userInput<=0) { System.out.println("A perfect number must be positive and greater than zero. So kindly enter number greater than zero."); } else { int sum =0; // Iterating till half of the number for(int i = 1; i<= userInput/2;i++) { // If number is divisible, add divisor. if(userInput%i==0) { sum = sum+i; } } // If sum is equal to number if(userInput==sum) { System.out.println(userInput+" is a perfect number."); } else { System.out.println(userInput+" is not a perfect number."); } } } public static void main(String[] args) { // User input for the number Scanner sc = new Scanner(System.in); System.out.println("Please enter the number to check for perfect number : "); int userInput = sc.nextInt(); sc.close(); System.out.println("You entered: " + userInput); perfectNumber(userInput); } }
Output:
[java]
Please enter the number to check for perfect number :
6
You entered: 6
6 is a perfect number.
=====================================================
Please enter the number to check for perfect number :
1
You entered: 1
1 is not a perfect number.
====================================================
Please enter the number to check for perfect number :
-10
You entered: -10
A perfect number must be positive and greater than zero. So kindly enter number greater than zero.
======================================================
Please enter the number to check for perfect number :
10
You entered: 10
10 is not a perfect number.
[/java]
#HappyCoding